4.6 成员访问运算符
点运算符(参见1.5.2节,第23页)和箭头运算符(参见3.4.1节,第110页)都可用于访问成员,其中,点运算符获取类对象的一个成员;箭头运算符与点运算符有关,表达式ptr->mem等价于(*ptr).mem:
- string s1 = "a string", *p = &s1;
- auto n = s1.size(); // 运行string对象s1的size成员
- n = (*p).size(); // 运行p所指对象的size成员
- n = p->size(); // 等价于(*p).size()
因为解引用运算符的优先级低于点运算符,所以执行解引用运算的子表达式两端必须加上括号。如果没加括号,代码的含义就大不相同了:
- // 运行p的size成员,然后解引用size的结果
- *p.size(); // 错误:p是一个指针,它没有名为size的成员
-
- 这条表达式试图访问对象p的size成员,但是p本身是一个指针且不包含任何成
箭头运算符作用于一个指针类型的运算对象,结果是一个左值。点运算符分成两种情况:如果成员所属的对象是左值,那么结果是左值;反之,如果成员所属的对象是右值,那么结果是右值。
4.6节练习
练习4.20:假设iter的类型是vector<string>::iterator,说明下面的表达式是否合法。如果合法,表达式的含义是什么?如果不合法,错在何处?
(a) *iter++; (b) (*iter)++; (c) *iter.empty()
(d) iter->empty(); (e) ++*iter; (f) iter++->empty();