php中die()與exit()的真正區別是什麼因,我們百度一下發現die是退出並釋放內存,exit是退出但不釋放內存了,那麼真的是這樣嗎,需要的朋友可以參考下
網上搜尋die與exit兩個函數的區別,大部分的」標準答案」都是說die是退出並釋放內存,exit是退出但不釋放內存。
這個解釋顯然是錯的,PHP手冊中已經說過「die — Equivalent to exit().This language construct is equivalent to exit(). 」兩者只是別名關係,除此之外完全一樣。
不過我還是很好奇,決定從原始碼中找找線索,看看php是如何處理的這個「別名」。
首先要清楚一點,die和exit都是」language construct」而非函數,網路上也有很多說某某某有回傳值是函數,某某無回傳值是結構,很多初學者總搞不清語言結構和函數的區別,用通俗點的話講,語言結構可以理解為語法本身的一種標識。像 、-、*、/這些也都是語言結構,if、else、for、while,這些都是語言結構。是語法本身的一部分。任何語言都會有這些東西,因為電腦看到 不會認為是應該做加法的。這需要編譯器轉換成機器碼也就是cpu能夠辨識的指令集。
php執行原始碼時的整個過程為,首先按照zend_language_scanner.l中定義的,將源碼中的echo、if之類的語言結構轉換成類似的T_ECHO、T_IF這些token,並且會去掉源碼中的空格,註解這些與程式邏輯無關的字元。 ,就形成了一些簡短的表達式,這就是詞法分析階段。然後會按照zend_vm_opcodes.h中定義的,將這些token轉換為op code。然後一條一行的執行這些op code。
上面大概解釋了php的編譯和執行的過程,以及語言結構的定義。下面進入正題。
我們也應該記得,php中有很多別名函數,像是:implode和join。無論是別名函數或別名語言結構,從實際效果角度講,都是一樣的,不過原始碼的處理方式肯定還是不一樣的。
我們先來看看這個別名語言結構是如何處理的,稍後再看別名函數。
zend_language_parser.c中,定義了一個巨集
#define T_EXIT 300
也定義了一個enum,裡面也有
#enum yytokentype { … T_EXIT = 300, …. }
這裡告訴我們,T_EXIT這個token,它的code是300。
再看zend_language_scanner.l,其中有這麼幾行程式碼。
<ST_IN_SCRIPTING>”exit” { return T_EXIT; } <ST_IN_SCRIPTING>”die” { return T_EXIT; }
也可以用下列php程式碼來決定:
<?php var_dump(token_get_all(“<?php die;exit;?>”));
傳回的結果中die和exit對應的token code,都是300。
現在關於die和exit的問題,我想大家應該可以確定了,只是名字不同,效果都是一樣的,沒有所謂的卸不卸載內存的問題。
PHP手冊:die()Equivalent to exit()。
說明:die()和exit()都是中止腳本執行函數;其實exit和die這兩個名字指向的是同一個函數,die()是exit()函數的別名。函數只接受一個參數,可以是一個程式回傳的數值或是一個字串,也可以不輸入參數,結果沒有回傳值。
參考:雖然兩者相同,但通常使用上也有細微的選擇性。例如:當傳遞給exit和die函數的值為0時,表示提前終止腳本的執行,通常用exit()這個名字。
echo "1111"; exit(0); echo "2222"; //22222不会被输出,因为程序运行到exit(0)时,脚本已经被提前终止,“马上断气”。
當程式出錯時,可以給它傳遞一個字串,它會原樣輸出在系統終端上,通常使用die()這個名字。
$fp=fopen("./readme.txt","r") or die("不能打开该文件");
php 變數在前台html 的textarea 中如何換行以及換行修改如何在PHP後台取得
mysql預存程序詳解以及
PHP呼叫MYSQL預存程序實例
###################以上是php die()與exit()的差異實例詳解的詳細內容。更多資訊請關注PHP中文網其他相關文章!