什么是死循环?帮你弄懂死循环的含义
首先请大家看这么一个简单的小程序:
#include
voidmain()
{
inti,b[10];
for(i=0;i<=10;i++)
{
b[i]=0;
}
}
请问这个程序是否有错?A.正常 B.越界 C.死循环
正确答案是C,相信选A或选B的朋友一定会很纳闷。事实上我也是如此,单单从程序的表面上看,按定义这应该是个越界,因为当循环进行到i == 10的时候,程序将试图将b[10]赋值为0,而C语言中,b[10]的声明就是指定b[0]~b[9]可用。
然而程序的结果你看到了,这是个死循环无疑。
也好,那么让汇编来告诉你——以及我——这一切的真相吧,在这之前请你把i和b[10]的定义改成:
int i = 0, b[10] = { 1, 2, 3, 4, 5, 6, 7, 8, 9, 10 };
然后,将这个程序反汇编,可以得到:
让我来解释一下这段汇编代码的含义吧。在系统的实现中,i和数组b[10]是分配在栈上的变量,在内存中的分布如下图:
现在你看到了,i所占据的正是b[10]的位置,而b[10] = 0;这一句会被这样运行:
*(&b[0] + 10) = 0;
所以这一句的结果,就是把0赋值给i。这样一来在第11次循环的时候,i将会被重新置为0,那么循环结束的条件也就永远不会满足了,循环也就是个死循环了。
事实上单单讨论C语言的内部实现并没有什么意义,而且这样书写的循环在程序设计中也绝对不能够出现。所以我所想要讨论的,就是如何让汇编帮助我们解决表面上无法看清楚的东西,仅此而已。
如何入侵redhat linux?入侵redhat linux的步骤
我写此文的目的不在于教人入侵,而是为了提高自身的技术和加强网络管理员的安全防范意识。仅此而已!粗心大意的网络管理员应该明白:由于你们一个小小的操作失误可能会导致整个网络全面沦陷!本文主要是围绕UNIX下
详情2018-01-13 20:02:38责编:llp 来源:驱动管家科迅会员上传webshell漏洞?文件webshell漏洞怎么修复?
会员上传文件漏洞,可以上传任意后缀user swfupload asp文件漏洞复制代码代码如下:If UpFileObj Form( "NoReName ")= "1 " Then & 39;不更名Dim PhysicalPath,FsoObj:Set FsoObj = KS InitialObject(KS Settin
详情2018-01-11 14:54:27责编:llp 来源:驱动管家openssh存在三大安全漏洞 这些漏洞怎么修复?
一:漏洞分析最近进行linux系统安全加固分析,进行漏洞扫描扫描分析,不扫不知道,一扫吓一跳,linux系统服务器的OPENSSH存在3大安全漏洞,祥如下:1:OpenSSH GSSAPI 处理远端代码执行漏洞漏洞分类 守护进程
详情2018-01-24 15:38:43责编:llp 来源:驱动管家windows密码怎么破解?这款密码清除软件可以轻松做到
当你在使用电脑时,不小心将管理员登录密码忘记了,怎么办呢?虽然网上和各IT杂志介绍了很多种破解管理员登录密码的方法,但操作起来都比较麻烦,并且针对不同的系统须要用不同的破解方法。例如,用破解Winodws 2
详情2018-01-30 09:59:15责编:llp 来源:驱动管家discuz x1.5漏洞分析:使用文件作为缓存就是包含漏洞的条件
DISCUZX1 5 本地文件包含漏洞,当然是有条件的,就是使用文件作为缓存。config_global php$_config[& 39;cache& 39;][& 39;type& 39;] = ‘file’;function cachedata($cachenames) {……$isfilec
详情2018-01-23 18:51:37责编:llp 来源:驱动管家百度知道漏洞 百度知道存在反射型xss漏洞怎么办?
百度知道百度知道存在反射型XSS,可以做诱惑点击导致蠕虫。http: zhidao baidu com utask qb info?callback=1 加强过滤。2 JSON接口存在风险:JSON接口需要设置Co
详情2018-02-05 09:31:22责编:llp 来源:驱动管家恶意软件的危害 怎么防御恶意软件?
移动设备的发展令大部分的企业的得到了很快的进步,但是一些网络安全性的问题总得不到解决,这主要的原因都归因于恶意软件,下面小编为大家介绍企业该怎么做好安全防御措施,需要的朋友快来看看你吧。恶意软件数
详情2018-01-17 18:58:34责编:llp 来源:驱动管家木马免杀有哪些绝招?木马免杀的五大绝招
常用的木马免杀方法绝招一:快速搞定瑞星文件查杀操作步骤: 第一步:用OD载入,来到程序的入口点。 第二步:把入口点的第一句PUSH EBP 改成POP EBP 然后保存就可以躲过瑞 星的表面查杀。绝招二:快速定位
详情2018-01-07 09:11:57责编:llp 来源:驱动管家javascript教程 javascript字符串如何被null字符截断
在IE中javascript的字符串可以被NULL字符截断,不过仅仅是getValue的时候截断 测试代码:alert(& 39;abc 0 def& 39;)如果只是这样最多就是spoofing,但配合IE(
详情2018-01-18 15:32:50责编:llp 来源:驱动管家服务器安全狗怎么添加用户?超简单!
前几天发现的,略无语,因为简单到。。直接在命令行下使用for l %i in (1,1,1000) do @net user test test add&@net localgroup administrators test add另存为 ad bat 使用for l %%i in
详情2018-01-18 11:25:50责编:llp 来源:驱动管家
- 驱动程序签名是什么?驱动程序数字签名有哪些用处
- AI技术或将改变农业领域 人们吃饱的同时更能吃好
- 买酷派酷玩6还是小米6?这两部手机有什么区别?
- excel自动换行功能怎么用?excel自动换行怎么操作?
- cain还原加密密码?cain如何还原flashfxp密文?
- IE浏览器总是提示“当前页面的脚本发生错误”是怎么回事?如何解决
- 小米手机如何省电?这里有七种方法可以省电
- 酷派大神note跑分是多少?酷派大神note性能评价如何?
- mp3格式的文件为什么图标显示异常?mp3格式图标异常解决办法
- ewebeditor编辑器漏洞分为哪些方面?怎么利用ewebeditor编辑器漏洞?
- 酷派5951值得买吗?买酷派5951还是红米1s?
- 阿里旺旺群发设置在哪儿?阿里旺旺可以群发消息吗?
- dedecms v5漏洞描述 dedecms v5漏洞如何检测?
- 【游戏攻略】房区战斗四大实用打法技巧 职业选手最多只会三种?
- 酷派大神f1这么刷机!酷派大神f1刷机指南
- 优化内存,酷派8720l可以删除哪些软件?
- 路由器和猫怎么连接?上网猫与路由器连接的具体操作是什么?
- 分区工具怎么使用?DG分区工具使用教程
- 为什么syn flood会造成危害?如何抵御syn flood攻击?
- php安全模式限制了什么?客户端脚本植入的防范方法