linux棧溢出的原因是什么

linux中,溢出的原因是系統棧是由高地址往低地址增長,而數據的寫入是按低地址往高地址的順序寫入,所以程序一旦沒有對輸入的字符數量做出限制,就會存在數據溢出當前棧的可能。棧溢出是緩存區溢出的一種,本質上是寫入棧的數據超過棧的大小造成的。

linux棧溢出的原因是什么

本教程操作環境:linux7.3系統、Dell G3電腦。

linux棧溢出的原因

概述

棧,就是那些由編譯器在需要的時候分配,在不需要的時候自動清除的變量的存儲區。里面的變量通常是局部變量、函數參數等;和相比,棧通常很小,在Linux下,通過ulimit -s可以查看棧的大小。

所謂棧溢出,是緩沖區溢出的一種,本質上是寫入棧的數據超過棧的大小,使得數據寫入其他單元,往往造成不可預期的后果,最常見的就是程序崩潰。

造成棧溢出的原因

系統棧是由高地址往低地址增長的, 而數據的寫入是按低地址到高地址的順序寫入. 如果程序沒有對輸入的字符數量做出限制, 就存在數據溢出當前棧幀以及覆蓋返回地址的可能, 從而實現控制程序的執行流。

實例如下

一個棧溢出的程序:

linux棧溢出的原因是什么

推薦學習:Linux視頻教程

以上就是

? 版權聲明
THE END
喜歡就支持一下吧
點贊10 分享