标题:运行包含以下代码段的程序将可能进入死循环,为什么是错的?
只看楼主
成诺
Rank: 1
等 级:新手上路
帖 子:7
专家分:0
注 册:2022-10-23
结帖率:100%
已结贴  问题点数:18 回复次数:2 
运行包含以下代码段的程序将可能进入死循环,为什么是错的?


int i = 1;
while(i>0){ i++; printf("%d ",i); }
搜索更多相关主题的帖子: 死循环 printf 运行 代码段 包含 
2022-11-05 19:36
不会游泳的虾
Rank: 7Rank: 7Rank: 7
等 级:贵宾
威 望:24
帖 子:101
专家分:643
注 册:2021-7-1
得分:9 
理论上这段代码是死循环,因为判断条件是 i > 0 ,循环体里 i++ ,所以 i 的值是始终大于 0 的。但计算机硬件位数是有限的,那么当 i 增长到超出所能表达的数据范围的数时溢出,i 的值就出现 i < 0 的情形,此时就不满足循环的条件了,退出循环。上面的代码稍加改造,可以去运行下,供参考:
程序代码:
#include <stdio.h>
int main()
{
    int i = 1;
    while(i > 0){ i+=i; printf("%d ",i); }
    return 0;
}


[此贴子已经被作者于2022-11-5 22:13编辑过]

2022-11-05 22:11
rjsp
Rank: 20Rank: 20Rank: 20Rank: 20Rank: 20
等 级:版主
威 望:507
帖 子:8890
专家分:53117
注 册:2011-1-18
得分:9 
具符号整型的溢出属于未定义行为。

编译器无须考虑i的溢出,那么在i不溢出的情况下,必然i>0成立。
即 while(i>0) 可优化为 while( true )
2022-11-05 22:12



参与讨论请移步原网站贴子:https://bbs.bccn.net/thread-510555-1-1.html




关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.173934 second(s), 7 queries.
Copyright©2004-2024, BCCN.NET, All Rights Reserved