[問題] memory stack 的問題

作者: kyuudonut (善良老百姓)   2016-08-27 22:05:40
最近寫 c code 一直想釐清一些問題
跟c程式沒有很直接相關,若發在這不妥再請麻煩版友告知了 m(_ _)m
最近在研讀virtual memory相關知識,大致上了解paging的運作模式
但仍不太懂 stack 往下長的實際情況是如何運作?
stack就我的理解基本上是:
程式在執行 function call 時,堆疊便會一直往下長
[問題一] process 是在 loading 時才知道分配到的 stack 的起始位置嗎?
[問題二] stack overflow 如何判定? 在此 stack 的大小是由誰決定的呢?
[問題二] 如果有多個 process 同時運作,各自 stack 的起始位置又是如何分配呢?
(一直往下長不會撞到嗎@@)
(當某 process 需要的 stack 大小超過兩個 page 又是如何維護?
page 如果不連續怎麼辦?)
[問題三] 一個程式有code, text區段,是直接從 heap 下面開始剩餘記憶體
隨機取一page各自載入嗎?還是 memory 還有在更細分區塊?
還請各位前輩指教,或是指引我關鍵字QQ 我會去查資料
小弟目前正在研讀"程式設計師的自我修養-連結,載入,程式庫"
這本書寫的很詳細,卻又引出更多疑問 orz
作者: stupid0319 (徵女友)   2016-08-27 22:21:00
看雪學院有一本加密與解密,有反組譯教學,可以看看
作者: epithet (epithet)   2016-08-27 23:26:00
二、可以在 stack 外圍設立一小段禁止寫入的區域,越界時才會觸動 二、 同一個 CPU 下,不會真的同時運作,切到的那個行程如果跟人相撞...其他行程的資料會被移到別處
作者: b0920075 (Void)   2016-08-28 01:37:00
stack好像有個機制會把一個值放在stack裡面,會檢察看有沒有被更改為其他值,有改到表示溢出。
作者: kyuudonut (善良老百姓)   2016-08-28 17:45:00
謝謝各位前輩的回覆!

Links booklink

Contact Us: admin [ a t ] ucptt.com