死循环的举例

死循环的举例,第1张

以下是一些死循环的例子。

C++的例子

#include<iostreamh>

int main()

{

for(int i=0;;i++)

{

cout<<char(i);

}

return 0;

}

C语言的死循环:

#include <stdioh>

main()

{

int a = 0;

while (a < 10)

{

printf(%d\n, a);

if (a = 5) {

printf(a equals 5!\n);

}

a++;

}

return 0;

}

上述程序会一直显示Infinite Loop字符串。

BASIC语言的死循环:

10 PRINTInfinite Loop

20 GOTO10'跳到行号=10的位置

X86汇编语言的例子:

loop:

; Code to loop here

jmploop

Python的例子:

whileTrue:

print(Infinite Loop) 以下是一个Visual Basic死循环的例子:

dimxasintegerdountilx > 5'根本不会有x>5的情形x = 1 x = x + 1loop

每一次运行循环时x会先设置为1,然后变为2,因为数值未大于5,所以永远不会退出。若将x = 1由循环内部移到循环之前即可以改善此一情形。

有些程序员可能因为不熟悉特定编程语言的语法而造成死循环,例如以下是一段C语言的程序:

#include <stdioh>

main()

{

int a=0;

while(a<10)

{

printf(%d\n,a);

if(a=5){//a设定为5,进入无穷回圈printf(a equals 5!\n);}

a++;

}

return0;

}

其预期输出是数字0至9,其中5和6中间会显示a equals 5!,但程序员在编写程序时将设置用的=运算符及判断相同的==运算符弄混了,因此程序会在每次运行循环时都会将a设置为5,因此变量a永远无法到达10,此循环就变成了死循环。 有时不适当的循环退出条件也可能会造成无预期的死循环,例如以下C语言的例子:

float x=01;

while(x!=11)

{

//可能会因为浮点运算的误差而出现问题

printf(x = %f\n,x);

x=x+01;

}

在有些 *** 作系统中,上述程序会运行10次循环然后退出,但有些系统中,上述程序却可能会一直运行,无法退出,问题主要在循环的退出条件(x != 11)要在二个浮点数相等时才退出,结果会依系统处理浮点数的方式而定,只要系统运行10次循环后的结果和11差一点点,上述程序就会变成死循环。

若将退出条件改为(x < 11)就没有这个问题,程序可能会多运行一次循环,但不会变成死循环。另一种解决方式则是用一个整数变量作为循环变量,再依此变量判断是否要退出循环。

在数值分析程序中也可能会出现无预期的死循环,例如程序需一直迭代到误差小于某特定值为止,但若因为运算中的舍去误差,使得误差一直无法小于该特定值,就会产生死循环。 奥尔德森循环(Alderson loop)是指一个循环有设置退出条件,但因为程序的写法(多半是编程错误),造成永远无法满足退出条件,在针对用户界面程序调试时最容易出现这类的问题。

以下C的伪代码中有一个奥尔德森循环,程序是要计算用户输入一串数字的和,用户输入0时退出循环,但程序中用了不正确的运算符:

sum=0;while(true){printf(Input a number to add to the sum or 0 to quit);i=getUserInput();if(i0){// 若i乘0为真,则使sum加上i的值sum+=i;// 但这不可能发生,因为不论i为何值(i 0)都是0。如果条件中用的是!=而非,代码就能正常运行}if(sum>100){break;// 终止循环。结束条件存在,但从来没有达到过,因为sum永远不会增加}}

“奥尔德森循环”是来自一个Microsoft Access的程序员,他编写的程序产生一个有模式的对话框,用户需要回应,程序才能继续运作,但对话框没有OK键或取消键,因此只要此对话窗出现,Access程序就无法继续运作。 无穷递归是一种由递归造成的死循环。例如以下计算阶乘的C语言程序

unsigned int fac(unsigned int a){

//n!=n(n-1)!

return(fac(a-1)a);

}

一般递归的程序会有一特定条件,此条件成立时直接计算结果,而不是通过递归来计算结果,若程序中未定义此条件,就会出现无穷递归。

无穷递归会造成堆栈溢出,而无穷递归不会退出,因此也是死循环的一种。不过若递归程序是使用尾部递归的处理方式,在有些编程语言(如Scheme)中会优化成循环,因此不会造成堆栈溢出。

上述的程序可以修改成没有无穷递归的程序。

unsigned int fac(unsigned int a){

if(a==0)

{//定义0!=1

return1;

}

else

{

return(fac(a-1)a);

}

}

ctrl+break或ctrl+c,有时要多按几下,然后结束所运行的程序保存即可。另copy外,建议你点击菜单工具--选项,选择环境选项卡,选中“启动程序时”“提示保存改变”,这样可zhidao以提醒你在运行前保存程序。

死循环

(无法靠自身的控制终止的循环)

编辑

在编程中,一个无法靠自身的控制终止的程序称为“死循环”。

例如在C语言程序中,语句“while(1)printf("");”就是一个死循环,运行它将无休止地打印号。

不存在一种算法,对任何一个程序及相应的输入数据,都可以判断是否会出现死循环。因此,任何编译系统都不做死循环检查。

在设计程序时,若遇到死循环,我们可以通过按下Ctrl+Pause/Break的方法,结束死循环。

然而,在编程中死循环并不是一个需要避免的问题,相反,在实际应用中,经常需要用到死循环。例如,我们使用的Windows *** 作系统下的窗口程序中的窗口都是通过一个叫消息循环的死循环实现的。在单片机、嵌入式编程中也经常要用到死循环。在各类编程语言中,死循环都有多种实现的方法,以C语言为例,可分别使用whilefor,goto实现。

表达式:

1、1

2、True

扩展资料:

while:

while(表达式){

  语句块

}

1、循环条件成立时的话,while 循环会一直执行下去,永不结束,成为“死循环”。

2、 循环条件不成立的话,while 循环就一次也不会执行。

include <stdioh>

int main(){

while(0){

printf("1");

}

return 0;

}

do-while循环:

一般形式为:

do{

语句块

}while(表达式);

do-while循环与while循环的不同在于:它会先执行“语句块”,然后再判断表达式是否为真,如果为真则继续循环;如果为假,则终止循环。因此,do-while 循环至少要执行一次“语句块”。

以上就是关于死循环的举例全部的内容,包括:死循环的举例、使用VB时调试一个程序,陷入死循环,如何停止、死循环怎么解等相关内容解答,如果想了解更多相关内容,可以关注我们,你们的支持是我们更新的动力!

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/zz/9819022.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-05-02
下一篇 2023-05-02

发表评论

登录后才能评论

评论列表(0条)

保存