記憶體的幾個區域分割
#1、堆疊區(stack)— 程式執行時間由編譯器自動分配,存放函數的參數值,局部變數的值等。 其操作方式類似於資料結構中的堆疊。程式結束時由編譯器自動釋放。 (建議學習:PHP影片教學)
2、堆疊區(heap) — 在記憶體開啟另一個儲存區域。 一般由程式設計師指派釋放, 若程式設計師不釋放,程式結束時可能由OS回收 。注意它與資料結構中的堆是兩回事,分配方式倒是類似鍊錶,呵呵。用malloc, calloc, realloc等分配記憶體的函數分配得到的就是在堆上
3、全域區(靜態區)(static)—編譯器編譯時即分配記憶體。 全域變數和靜態變數的儲存是放在一塊的。對於C語言初始化的全域變數和靜態變數在一塊區域, 未初始化的全域變數和未初始化的靜態變數在相鄰的另一塊區域。而C 則沒有這個差異 - 程式結束後由系統釋放
4、文字常數區 —常數字串就是放在這裡的。 程式結束後由系統釋放
5、程式碼區—存放函數體的二進位程式碼。
用 C 語言程式設計時,開發者要手動地進行記憶體管理。 因為 PHP 經常用作 Web 伺服器的模組,記憶體管理與預防記憶體洩漏緊密關聯。
此外要知道 PHP 可能用於執行緒環境中,這表示全域變數可能導致競爭狀況。有關執行緒內全域資料處理的資訊請參閱作為執行緒隔離設施的 執行緒安全的資源管理器。
此外,Zend 引擎要面對一個十分特殊的使用模式:在一段比較短的時間內,許多 zval 結構大小的記憶體區塊和其他的小記憶體區塊被申請又再被釋放。 PHP 的記憶體管理也重視 memory_limit(記憶體限制)。
Note: 和與C 標準函式庫相似的部分不同,如果分配請求的記憶體出錯,Zend 引擎的記憶體管理函數不會傳回NULL 值,而會跳出併中止目前請求。
如上所述,防止有記憶體洩漏並儘可能快地釋放所有記憶體是記憶體管理的重要組成部分。因為安全原因,在請求結束時, Zend 引擎會釋放所有由上面提到的 API 所分配的記憶體。如果 PHP 使用 --enable-debug 配置選項進行構建,這將產生一個警告。
PHP 的洩漏警報
ZEND_FUNCTION(leak) { long leakbytes = 3; if (zend_parse_parameters(ZEND_NUM_ARGS() TSRMLS_CC, "|l", &leakbytes) == FAILURE) { return; } emalloc(leakbytes); }
以上是php記憶體的幾個區域劃分的詳細內容。更多資訊請關注PHP中文網其他相關文章!