彻底搞清 C/C++中a++与++a的区别
2016-06-29 08:51
281 查看
1,转载地址:
http://blog.163.com/tianhit@yeah/blog/static/1657478212010722953444/
2,首先 a++和++a 的定义:看个例子
A: a=5; b=++a; // 相当于a=a+1;b=a; 结果是a=6,b=6
B: a=5; b=a++; // 相当于b=a;a=a+1; 结果是a=6,b=5
所以书上有:
(1) 如果用前缀运算符对一个变量增1(减1),则在将该变量增1(减1)后,用新值在表达式中进行其他的运算。
(2) 如果用后缀运算符对一个变量增1(减1),则用该变量的原值在表达式中进行其他的运算后,再将该变量增1(减1)后。
这里就有个问题,对于后缀运算,”用该变量的原值在表达式中进行其他的运算后“该如何理解,也就是说啥时才算表达式运算完啦。
举个列子:求a的最终值
http://blog.163.com/tianhit@yeah/blog/static/1657478212010722953444/
2,首先 a++和++a 的定义:看个例子
A: a=5; b=++a; // 相当于a=a+1;b=a; 结果是a=6,b=6
B: a=5; b=a++; // 相当于b=a;a=a+1; 结果是a=6,b=5
所以书上有:
(1) 如果用前缀运算符对一个变量增1(减1),则在将该变量增1(减1)后,用新值在表达式中进行其他的运算。
(2) 如果用后缀运算符对一个变量增1(减1),则用该变量的原值在表达式中进行其他的运算后,再将该变量增1(减1)后。
这里就有个问题,对于后缀运算,”用该变量的原值在表达式中进行其他的运算后“该如何理解,也就是说啥时才算表达式运算完啦。
举个列子:求a的最终值
int a=3; a+=a+=a++*a--; 计算过程如下: 先算a++*a-- 由于a=3 a++等于3 //这里后缀++中的第二步自加运算还没有进行 a--等于3 //这里后缀--中的第二步自减运算还没有进行 所以 ++*a-- 等于9 a+=a++*a-- 等于a+=9等于a=a+9=3+9=12 在算a+=a 等于a=a+12=12+12=24 然后在进行再后缀++中的第二步自加运算和后缀--中的第二步自减运算 即进行 a=a+1;此时a=25;再进行a=a-1;此时a=24 所以最终a=24 说明在一个表达中,无论有多少个等号(赋值号)都必须进行完所有的运算符后,才能进行后缀自加,自减。那么什么时候才能 算本计算单位已经结束。下面某些摘自《C语言深度剖析》 i++ 在遇到每个逗号,分号后,才认为本计算单位已经结束,i 这时候自加。 关于逗号表达式与“++”或“--”的连用,还有一个比较好的例子: int x; int i = 3;x = (++i, i++, i+10); 问 x的值为多少?i的值为多少? 按照上面的讲解,可以很清楚的知道,逗号表达式中,i 在遇到每个逗号后,认为本计算 单位已经结束,i 这时候自加。所以,本例子计算完后,i的值为5,x的值为 15。 关于符号的贪心法 C 语言有这样一个规则:每一个符号应该包含尽可能多的字符。也就是说,编译器将程 序分解成符号的方法是,从左到右一个一个字符地读入,如果该字符可能组成一个符号, 那么再读入下一个字符,判断已经读入的两个字符组成的字符串是否可能是一个符号的组 成部分;如果可能,继续读入下一个字符,重复上述判断,直到读入的字符组成的字符串 已不再可能组成一个有意义的符号。这个处理的策略被称为“贪心法” 。需要注意到是,除 了字符串与字符常量,符号的中间不能嵌有空白(空格、制表符、换行符等) 。比如:==是单个符号,而==是两个等号。 按照这个规则可能很轻松的判断 a+++b表达式与 a++ +b一致。那++i+++i+++i;会被解 析成什么样子呢?希望读者好好研究研究。另外还可以考虑一下这个表达式的意思a+++++b? 分析: ++i+++i+++i 由于后缀自增,自减优先级比前缀高(ANSI/ISO C++中),编译器等效理解 为++(i++)+(i++)+i,而i++不可以作左值,所以++(i++)错误,故此表达式错误 a+++++b 编译器将其理解为(a++)++ +b, 由于a++不可以作左值,所以(a++)++错误,故此表达式错误 另外特别注意 ++i在C中不是左值,在C++中才是。在C语言中像 int i=0,a=2,b=3;++i=a+b;这个表达式是非法的。 i++在C和C++中都不能作左值。
相关文章推荐
- 使用MinGW编译Boost
- 使用Boost的DLL库管理动态链接库
- c++运算符的重载
- C++中32位单精度浮点数有效数字是多少位?
- c++ string 和封装上
- 树状数组 Binary Indexed Tree
- 提高项目12.5-数组大折腾
- c语言之跨平台的文件拷贝filecopy
- 提高项目12.4-数组大折腾
- C++之操作符重载和友元学习笔记
- 提高项目12.2数组大折腾
- 用栈来表示队列
- C++中的typeid关键字
- pixhawk commander.cpp的飞行模式切换解读
- 提高项目12.1-数组大折腾 加倍
- 提高项目12-数组大折腾
- idlcpp 功能改进
- 2016 大一下学期期末C++课程总结
- C++16、文件读写
- 小型银行系统函数版