Linux下栈溢出是什么原因,栈溢出的程序是怎样的
Admin 2022-07-19 群英技术资讯 462 次浏览
在linux中,栈溢出的原因是系统栈是由高地址往低地址增长,而数据的写入是按低地址往高地址的顺序写入,所以程序一旦没有对输入的字符数量做出限制,就会存在数据溢出当前栈的可能。栈溢出是缓存区溢出的一种,本质上是写入栈的数据超过栈的大小造成的。
本教程操作环境:linux7.3系统、Dell G3电脑。
概述
栈,就是那些由编译器在需要的时候分配,在不需要的时候自动清除的变量的存储区。里面的变量通常是局部变量、函数参数等;和堆相比,栈通常很小,在Linux下,通过ulimit -s可以查看栈的大小。
所谓栈溢出,是缓冲区溢出的一种,本质上是写入栈的数据超过栈的大小,使得数据写入其他单元,往往造成不可预期的后果,最常见的就是程序崩溃。
造成栈溢出的原因
系统栈是由高地址往低地址增长的, 而数据的写入是按低地址到高地址的顺序写入. 如果程序没有对输入的字符数量做出限制, 就存在数据溢出当前栈帧以及覆盖返回地址的可能, 从而实现控制程序的执行流。
实例如下
一个栈溢出的程序:
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:mmqy2019@163.com进行举报,并提供相关证据,查实之后,将立刻删除涉嫌侵权内容。
猜你喜欢
linux系统安装mysql的具体操作你真的知道吗?需要了解清楚这方面内容的朋友可以看一看小编所整理的资料,如果你感兴趣的话千万不要错过了。
linux的进程调度发生的情况:1、进程状态转换的时刻,进程终止、进程睡眠,进程要调用“sleep()”或“exit()”等函数进行状态转换,这些函数会主动调用调度程序进行进程调度;2、当前进程的“current->counter=0”时,进程的时间片是由时钟中断来更新的;3、当设备驱动程序执行长而重复的任务时,直接调用调度程序;4、进程从中断、异常及系统调用返回到用户态时。
在linux中,32位平台和64位平台中的short都占2个字节;linux中只有long长整型、void(c语言中,void为“不确定类型”)在32位中是4个字节,在64位中是8个字节。
linux解压命令是什么?linux解压缩命令有很多,例如比较常用的tar命令、gunzip或gzip命令、bzip2或bunzip2命令、rar命令等等,那么具体怎样实现解压缩呢?接下来我们详细了解看看。
linux系统之虚拟内存的相关内容,不知道朋友们了解多少,对这方面需要深入探索的朋友,可以看看小编所整理的资料,或多或少能在工作中帮助到你 。
成为群英会员,开启智能安全云计算之旅
立即注册Copyright © QY Network Company Ltd. All Rights Reserved. 2003-2020 群英 版权所有
增值电信经营许可证 : B1.B2-20140078 粤ICP备09006778号 域名注册商资质 粤 D3.1-20240008