C语言程序设计过程中,内存溢出是常见的错误情况。主要是针对使用指针时的情况,一种是申请了内存,但在后面这个指针在没有释放的情况下,又指向了另一个内存地址,这样原内存就没有任何指针指向它,因而导致无法释放空间,所以内存就溢出了,也有可能是有多个指针指向同一地址,从而出现多次释放的情况。
栈溢出一般和操作指针有关系(包括本质上是指针的各种形式),比如调用不定变量个数的函数时(像printf、scanf这种),没有按约定传入适当的参数个数;函数操作传入的数组下标越界等;得到指向局部变量的指针后,做不合适的偏移操作。以上这些都有可能造成栈溢出。
各种信息通过交易或非交易的方式流出原来拥有的主体的过程。信息溢出源于信息的流动性和扩散性。从公共利益角度看,大量的、加速的信息溢出推动了整个社会的发展和进步;从信息拥有者的角度来看,信息溢出所带来的正面和负面影响都值得关注。
在计算机中,当要表示的数据超出计算机所使用的数据的表示范围时,则产生数据的溢出。
溢出原因
数据类型超过了计算机字长的界限就会出现数据溢出的情况。导致内存溢出问题的原因有很多,比如:
(1) 使用非类型安全(non-type-safe)的语言如 C/C++ 等。
(2) 以不可靠的方式存取或者复制内存缓冲区。
(3)编译器设置的内存缓冲区太靠近关键数据结构。
因素分析
1.内存溢出问题是 C 语言或者 C++ 语言所固有的缺陷,它们既不检查数组边界,又不检查类型可靠性(type-safety)。众所周知,用 C/C++ 语言开发的程序由于目标代码非常接近机器内核,因而能够直接访问内存和寄存器,这种特性大大提升了 C/C++ 语言代码的性能。只要合理编码,C/C++应用程序在执行效率上必然优于其它高级语言。然而,C/C++ 语言导致内存溢出问题的可能性也要大许多。其他语言也存在内存溢出问题,但它往往不是程序员的失误,而是应用程序的运行时环境出错所致。
2. 当应用程序读取用户(也可能是恶意攻击者)数据,试图复制到应用程序开辟的内存缓冲区中,却无法保证缓冲区的空间足够时(换言之,假设代码申请了 N 字节大小的内存缓冲区,随后又向其中复制超过 N 字节的数据)。内存缓冲区就可能会溢出。想一想,如果你向 12 盎司的玻璃杯中倒入 16 盎司水,那么多出来的 4 盎司水怎么办?当然会满到玻璃杯外面了!
3. 最重要的是,C/C++编译器开辟的内存缓冲区常常邻近重要的数据结构。假设某个函数的堆栈紧接在在内存缓冲区后面时,其中保存的函数返回地址就会与内存缓冲区相邻。此时,恶意攻击者就可以向内存缓冲区复制大量数据,从而使得内存缓冲区溢出并覆盖原先保存于堆栈中的函数返回地址。这样,函数的返回地址就被攻击者换成了他指定的数值;一旦函数调用完毕,就会继续执行“函数返回地址”处的代码。非但如此,C++ 的某些其它数据结构,比如 v-table 、例外事件处理程序、函数指针等,也可能受到类似的攻击。
到此,以上就是小编对于c语言内存溢出原因的问题就介绍到这了,希望这3点解答对大家有用。
新闻名称:c语言为什么会溢出?(c语言内存溢出如何解决)
标题来源:http://www.csdahua.cn/qtweb/news1/339851.html
网站建设、网络推广公司-快上网,是专注品牌与效果的网站制作,网络营销seo公司;服务项目有等
声明:本网站发布的内容(图片、视频和文字)以用户投稿、用户转载内容为主,如果涉及侵权请尽快告知,我们将会在第一时间删除。文章观点不代表本网站立场,如需处理请联系客服。电话:028-86922220;邮箱:631063699@qq.com。内容未经允许不得转载,或转载时需注明来源: 快上网