C语言那年踩过的坑--局部变量,静态变量,全局变量在内存中存放的位置
先看幾個(gè)概念:
1、bss是英文block started by symbol的簡(jiǎn)稱(chēng),通常是指用來(lái)存放程序中未初始化的全局變量的一塊內(nèi)存區(qū)域,在程序載入時(shí)由內(nèi)核清0。bss段屬于靜態(tài)內(nèi)存分配。它的初始值也是由用戶(hù)自己定義的連接定位文件所確定,用戶(hù)應(yīng)該將它定義在可讀寫(xiě)的ram區(qū)內(nèi),源程序中使用malloc分配的內(nèi)存就是這一塊,它不是根據(jù)data大小確定,主要由程序中同時(shí)分配內(nèi)存最大值所確定,不過(guò)如果超出了范圍,也就是分配失敗,可以等空間釋放之后再分配。
?2、text段是程序代碼段,在at91庫(kù)中是表示程序段的大小,它是由編譯器在編譯連接時(shí)自動(dòng)計(jì)算的,當(dāng)你在鏈接定位文件中將該符號(hào)放置在代碼段后,那么該符號(hào)表示的值就是代碼段大小,編譯連接時(shí),該符號(hào)所代表的值會(huì)自動(dòng)代入到源程序中。
?3、data包含靜態(tài)初始化的數(shù)據(jù),所以有初值的全局變量和static變量在data區(qū)。段的起始位置也是由連接定位文件所確定,大小在編譯連接時(shí)自動(dòng)分配,它和你的程序大小沒(méi)有關(guān)系,但和程序使用到的全局變量,常量數(shù)量相關(guān)。
?4、stack保存函數(shù)的局部變量和參數(shù)。是一種“后進(jìn)先出”(last in first out,lifo)的數(shù)據(jù)結(jié)構(gòu),這意味著最后放到棧上的數(shù)據(jù),將會(huì)是第一個(gè)從棧上移走的數(shù)據(jù)。對(duì)于哪些暫時(shí)存貯的信息,和不需要長(zhǎng)時(shí)間保存的信息來(lái)說(shuō),lifo這種數(shù)據(jù)結(jié)構(gòu)非常理想。在調(diào)用函數(shù)或過(guò)程后,系統(tǒng)通常會(huì)清除棧上保存的局部變量、函數(shù)調(diào)用信息及其它的信息。棧另外一個(gè)重要的特征是,它的地址空間“向下減少”,即當(dāng)棧上保存的數(shù)據(jù)越多,棧的地址就越低。棧(stack)的頂部在可讀寫(xiě)的ram區(qū)的最后。?
?5、heap保存函數(shù)內(nèi)部動(dòng)態(tài)分配內(nèi)存,是另外一種用來(lái)保存程序信息的數(shù)據(jù)結(jié)構(gòu),更準(zhǔn)確的說(shuō)是保存程序的動(dòng)態(tài)變量。堆是“先進(jìn)先出”(first in first out,fifo)數(shù)據(jù)結(jié)構(gòu)。它只允許在堆的一端插入數(shù)據(jù),在另一端移走數(shù)據(jù)。堆的地址空間“向上增加”,即當(dāng)堆上保存的數(shù)據(jù)越多,堆的地址就越高。
遇到的問(wèn)題:
以前這些我都記得,今天遇到實(shí)際問(wèn)題時(shí)候,發(fā)現(xiàn)遠(yuǎn)遠(yuǎn)不是這回事,全局變量能放在text段嗎?
的確可以的,其實(shí),我今天就遇到了這種情況,這個(gè)配置的區(qū)域?qū)嶋H上是可以在link文件中修改的,假如我的link文件是這樣子的:
其實(shí),這種情況下,假如我定義個(gè)const 類(lèi)型的全局變量,該全局變量就會(huì)在text段了,看來(lái),計(jì)算的的東西,還是要理解原理才行啊.不過(guò),這個(gè)也是反復(fù)的過(guò)程,有誰(shuí)不經(jīng)過(guò)磨難,就能快速成長(zhǎng)呢?
轉(zhuǎn)載于:https://www.cnblogs.com/dylancao/p/9936957.html
總結(jié)
以上是生活随笔為你收集整理的C语言那年踩过的坑--局部变量,静态变量,全局变量在内存中存放的位置的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問(wèn)題。
- 上一篇: 软件设计文档国家标准—软件需求说明书(G
- 下一篇: 华为透露成长秘诀:信息化建设铸就发展奇迹