自增自减
前自增 ++c
前自减 --c
后自增 c++
后自减 c--
1,自增运算符相当于+=1,自减运算符相当于-=1,因此自增自减运算符是可以被替代的。
2,前自增/自减和后自增/自减的区别在于,前自增/自减是先增加/减少值,然后返回结果的引用。后自增/自减是先创建一个该对象的副本,然后再增加/减少值,最后返回副本。
3,由于前自增/自减返回的是引用,后自增/自减返回的是复制,因此,一般而言,前自增/自减的效率要更高。因此如果不是必须要使用后自增/自减,都应该使用前自增/自减。例如在使用for循环的时候。
4,布尔值不允许被前/后自减,但是可以被前/后自增,如果对一个布尔值使用前/后自增,那么结果仍然会被设置为布尔值。c++17修改规定为布尔值不再允许被前/后自增。
自增自减运算符重载
前自增 operator++()
前自减 operator--()
后自增 operator++(int)
后自减 operator--(int)
在重载后自增/自减运算符的时候,参数列表中有一个int。因此可能有人会对此感到困惑,这里为什么有一个int?它起到了什么作用?它本身没有起到什么作用,它主要就是为了区分前/后自增而设置的一个参数,定义的时候就是这样做的。
自增自减参与运算
注意:我们应当只把自增自减简单的用于+=1或-=1这样的简单运算。不要让自增自减参与复杂离奇的计算。
#include <iostream>
using namespace std;
int main()
{
int c = 0;
// ++++c是可以的,因为前自增返回的是引用
cout << ++++c << endl;
// c++++是不行的,因为后自增返回的是副本不可以再直接用于后自增
// cout << c++++ << endl;
// 请不要让自增自减参与复杂离奇的计算
// 并且试图按照步骤算出结果,这种行为是不合适的
// int d = c++ * ++c;
// cout << d << endl;
}
为什么叫c++
通过自增自减运算符,有人明白了为什么c++会叫c++,而不是叫++c。
那么,你认为他们的想法是有道理的吗?