栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 面试经验 > 面试问答

增量逻辑

面试问答 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

增量逻辑

引用Java语言规范,15.7评估顺序:

Java编程语言保证运算符的操作数似乎按特定的评估顺序(即 从左到右)进行 评估。

评估 右侧操作数的任何部分之前,似乎已对二进制运算符的 左侧操作数 进行了 完全 评估。

如果该运算符是 复合赋值运算符
(第15.26.2节),则对左操作数的求值包括记住左操作数所表示的
变量 以及 获取并保存该变量的值 以用于隐式二进制操作。

因此,从本质上讲, 评估右侧 之前

i += ++i
会记住
i
左侧的旧值。 __

请记住,操作数的 求值顺序 和运算符的 优先级 是两回事。

逐步显示评估顺序,并在{大括号}中保存值:

int i = 0;i    = i    += (++i + (i    += 2 + --i) - ++i); // i = 0i{0} = i    += (++i + (i    += 2 + --i) - ++i); // i = 0i{0} = i{0} += (++i + (i    += 2 + --i) - ++i); // i = 0i{0} = i{0} += (1   + (i    += 2 + --i) - ++i); // i = 1i{0} = i{0} += (1   + (i{1} += 2 + --i) - ++i); // i = 1i{0} = i{0} += (1   + (i{1} += 2 + 0  ) - ++i); // i = 0i{0} = i{0} += (1   + (i{1} += 2      ) - ++i); // i = 0i{0} = i{0} += (1   + 3      - ++i); // i = 3i{0} = i{0} += (4 - ++i); // i = 3i{0} = i{0} += (4 - 4  ); // i = 4i{0} = i{0} += 0        ; // i = 4i{0} = 0     ; // i = 00 ; // i = 0

跟进编辑问题

如果我们命名初始值

I
和常量
N

int i = I;i = i += (++i + (i += N + --i) - ++i);

然后我们可以看到这些值是:

i{I} = i{I} += ((I+1) + (i{I+1} += N + I) - ((I+1+N+I)+1));i{I} = i{I} += (I + 1 + (I + 1 + N + I) - (I + 1 + N + I + 1));i{I} = i{I} += (I + 1 + I + 1 + N + I - I - 1 - N - I - 1);i{I} = i{I} += I;i{I} = I + I;i = 2 * I;


转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/398231.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号