自增操作符和箭头操作符

来源:互联网 发布:阿里云按流量计费 编辑:程序博客网 时间:2024/05/23 00:07

1.自增和自减操作符

自增(++)和自减(--)操作符为对象加1或减1操作提供了方便简短的实现方式。有前置和后置两种使用形式。
前置操作使该操作数加1或减1,操作结果是修改后的值。后置操作数同样对操作数加1或(减1),但操作后产生操作数原来的、未修改的值作为表达式的结果:
int i = 0, j;j = ++i;  // j=1,i=1:prefix yields incremented valuej = i++; // j=1,i=2:postfix yields unincremented value

因为前置操作返回加1后的值,所以返回对象的本身,这是左值。而后置操作返回的则是右值。

建议:只有在必要时才使用后置操作符
因为前置操作需要做的工作更少,只需加1后返回加1后的结果即可。而后置操作则必须先保存操作数之前的值,以便返回未加1之前的值作为操作的结果。对于 Int 型对象和指针,编译器可优化掉这份额外工作。但是对于更多的复杂的迭代器类型,这种额外工作可能会话费更大的代价。因此,养成使用前置操作这个好习惯,就不必操心性能差异的问题。

1.1 后置操作符返回未加1的值

如果在单个复合表达式中使用变量的当前值,然后再加1时,通常使用后置的++和--。
vector<int> ivec;int cnt = 10;// add elements 10...1 to ivecwhile (cnt > 0)      ivec.push_back(cnt--);

1.2 在单个表达式中组合使用解引用和自增操作

下面的程序使用了一种非常通用的C++编程模式输出ivec的内容:
vector<int>::iterator iter = ivec.begin();// print 10 9 8...1while (iter != ivec.end())      cout << *iter++ <<endl;
由于后自增操作的优先级高于解引用操作,因此*iter++等效于*(iter++)。字表达式iter++使iter加1,然后返回iter原值的副本作为该表达式的结果。因为解引用操作*的操作数是iter未加1之前的副本。
      这种用法的根据在于后自增操作返回其操作数原值(没有加1)的副本。如果返回的是加1后的值,则解引用该值将导致错误的结果:ivec的第一个元素没有输出,并企图对一个多余的元素进行解引用。

建议:简介就是美
上面的输出代码不采用下面这种冗长的等效代码:
cout << *iter << endl;++iter;


2.箭头操作符

C++语言为包含点操作符和解引用操作符的表达式提供了一个同义词:箭头操作符(->)。点操作符用于获取类类型对象的成员:
item.same_isbn(item2); // run the same_isbn member of item1 
如果有一个指向Sale_item 对象的指针(或迭代器),则在使用点操作符前,需要对指针(或迭代器)进行解引用:
Sale_item *sp = &item1;(*sp).same_isbn(item2); // run same_isbn on object to which sp points
这里,对 sp 进行解引用以获得指定的 Sales_item 对象。然后使用点操作符调用指定对象的same_isbn 成员函数。在上述用法中,注意必须用圆括号把解引用括起来,因为解引用的优先级低于点操作符。如果漏掉圆括号,则这段代码的含义就完全不同了:
//run the same_isbn member of sp then dereference the result!*sp.same_isbn(item2);  // error: sp has np member named same_isbn  
这个表达式企图获得sp 对象的same_isbn 成员。等价于:
*(sp.same_isbn(item2)); // equivalent to *sp.same_isbn(item2)
然而,sp是一个没有成员的指针。这段代码无法通过编译。
 
    因为编程时很容易忘记圆括号,而且这类代码又经常使用,所以C++为在点操作符后使用的解引用操作定义了一个同义词:箭头操作符(->)。假设有一个指向类类型对象的指针(或迭代器),下面的表达式互相等价:
(*p).foo;  // dereference p to get an object and fetch its member named foop->foo; //equivalent way to fetch the foo from the object to which p points
具体地,可将same_isbn 的调用重写为:
sp->same_isbn(item2);
















0 0
原创粉丝点击