主要從事網(wǎng)頁設計、PC網(wǎng)站建設(電腦版網(wǎng)站建設)、wap網(wǎng)站建設(手機版網(wǎng)站建設)、響應式網(wǎng)站建設、程序開發(fā)、微網(wǎng)站、微信小程序等,憑借多年來在互聯(lián)網(wǎng)的打拼,我們在互聯(lián)網(wǎng)網(wǎng)站建設行業(yè)積累了豐富的網(wǎng)站設計、成都做網(wǎng)站、網(wǎng)絡營銷經(jīng)驗,集策劃、開發(fā)、設計、營銷、管理等多方位專業(yè)化運作于一體,具備承接不同規(guī)模與類型的建設項目的能力。
代碼段(.text),也稱文本段(Text Segment),存放著程序的機器碼和只讀數(shù)據(jù),可執(zhí)行指令就是從這里取得的。如果可能,系統(tǒng)會安排好相同程序的多個運行實體共享這些實例代碼。這個段在內(nèi)存中一般被標記為只讀,任何對該區(qū)的寫操作都會導致段錯誤(Segmentation Fault)。
數(shù)據(jù)段,包括已初始化的數(shù)據(jù)段(.data)和未初始化的數(shù)據(jù)段(.bss),前者用來存放保存全局的和靜態(tài)的已初始化變量,后者用來保存全局的和靜態(tài)的未初始化變量。數(shù)據(jù)段在編譯時分配。
堆棧段分為堆和棧:
堆(Heap):用來存儲程序運行時分配的變量。
堆的大小并不固定,可動態(tài)擴張或縮減。其分配由malloc()、new()等這類實時內(nèi)存分配函數(shù)來實現(xiàn)。當進程調(diào)用malloc等函數(shù)分配內(nèi)存時,新分配的內(nèi)存就被動態(tài)添加到堆上(堆被擴張);當利用free 等函數(shù)釋放內(nèi)存時,被釋放的內(nèi)存從堆中被剔除(堆被縮減) 堆的內(nèi)存釋放由應用程序去控制,通常一個new()就要對應一個delete(),如果程序員沒有釋放掉,那么在程序結束后操作系統(tǒng)會自動回收。
棧(Stack)是一種用來存儲函數(shù)調(diào)用時的臨時信息的結構,如函數(shù)調(diào)用所傳遞的參數(shù)、函數(shù)的返回地址、函數(shù)的局部變量等。 在程序運行時由編譯器在需要的時候分配,在不需要的時候自動清除。
棧的特性: 最后一個放入棧中的物體總是被最先拿出來,這個特性通常稱為先進后出(FILO)隊列。
棧的基本操作: PUSH操作:向棧中添加數(shù)據(jù),稱為壓棧,數(shù)據(jù)將放置在棧頂; POP操作:POP操作相反,在棧頂部移去一個元素,并將棧的大小減一,稱為彈棧。
堆和棧的區(qū)別:
1.分配和管理方式不同 :
堆是動態(tài)分配的,其空間的分配和釋放都由程序員控制。
棧由編譯器自動管理。棧有兩種分配方式:靜態(tài)分配和動態(tài)分配。
靜態(tài)分配由編譯器完成,比如局部變量的分配。
動態(tài)分配由alloca()函數(shù)進行分配,但是棧的動態(tài)分配和堆是不同的,它的動態(tài)分配是由編譯器進行釋放,無須手工控制。
2.產(chǎn)生碎片不同
對堆來說,頻繁的new/delete或者malloc/free勢必會造成內(nèi)存空間的不連續(xù),造成大量的碎片,使程序效率降低。
對棧而言,則不存在碎片問題,因為棧是先進后出的隊列,永遠不可能有一個內(nèi)存塊從棧中間彈出。
3.生長方向不同
堆是向著內(nèi)存地址增加的方向增長的,從內(nèi)存的低地址向高地址方向增長。
棧的生長方向與之相反,是向著內(nèi)存地址減小的方向增長,由內(nèi)存的高地址向低地址方向增長。
創(chuàng)新互聯(lián)www.cdcxhl.cn,專業(yè)提供香港、美國云服務器,動態(tài)BGP最優(yōu)骨干路由自動選擇,持續(xù)穩(wěn)定高效的網(wǎng)絡助力業(yè)務部署。公司持有工信部辦法的idc、isp許可證, 機房獨有T級流量清洗系統(tǒng)配攻擊溯源,準確進行流量調(diào)度,確保服務器高可用性。佳節(jié)活動現(xiàn)已開啟,新人活動云服務器買多久送多久。
本文標題:程序在內(nèi)存中的分布-創(chuàng)新互聯(lián)
URL分享:http://aaarwkj.com/article34/goese.html
成都網(wǎng)站建設公司_創(chuàng)新互聯(lián),為您提供網(wǎng)站設計、App設計、微信公眾號、網(wǎng)站設計公司、搜索引擎優(yōu)化、自適應網(wǎng)站
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)
猜你還喜歡下面的內(nèi)容