奇怪++操作
2015-07-18 08:03
435 查看
#include <stdio.h> int main(void) { int j, i = 3; printf("j = %d\n", j = (++i) + (++i) + (++i)); i = 3; printf("j = %d\n", j = (i++) + (i++) + (i++)); i = 3; printf("j = %d\n", j = (++i) + (i++) + (++i)); return 0; } /* 结果: * j = 16 * j = 9 * j = 13 * */
#include <stdio.h> #define SQUARE(x) ((x)*(x)) int main(void) { int a = 5; int b, c; b = SQUARE(a++); a = 5; c = SQUARE(++a); printf("b: %d, c: %d\n", b, c); a = 5; b = (a++)*(a++); a = 5; c = (++a)*(++a); printf("b: %d, c: %d\n", b, c); a = 5; b = (a++)*(a++)*(a++); a = 5; c = (++a)*(++a)*(++a); printf("b: %d, c: %d\n", b, c); a = 5; b = (a++)*(a++)*(++a); a = 5; c = (++a)*(a++)*(++a); // 6*6*7 ? ? ? a = 5; c = (++a)*(a++); // 6*6 ?? ? printf("b: %d, c: %d\n", b, c); return 0; }
运行结果:
b: 25, c: 49
b: 25, c: 49
b: 125, c: 392
b: 150, c: 36
++ 什么是法律表达式求值?
反编译它?
相关文章推荐
- constant属性详解
- 排序算法之二分法(折半)插入排序算法
- Lumia刷机Win10 Mobile 10.0.10166惊魂记
- equals,==
- 安卓布局查看器uiautomatorviewer的使用
- 2015年需要了解的前端框架和语言
- 排序算法之直接插入排序
- python递归删除目录文件
- HDU 4627(最小公倍数最大问题)
- 核心动画
- MKNetworkKit 使用
- ACM暑期计划 —— 第三天
- 请珍惜身边的人
- 我这个站长是怎么炼成的
- Median of two Sorted Arrays
- 微软强制Win10家庭版用户自动安装所有系
- 经典排序算法分析及其Java实现
- CentOS安装Mysql5.5
- 课程设计——银行系统
- 初试zabbix基础概念