大多數的人都會以為global和$GLOBALS[]只是在寫法上面有所不同,但是實際上並不是這樣的,下面我們就來看一下它們之間究竟有何區別。
根據官方的解釋是
$GLOBALS['var'] 是外部的全域變數$var本身。
global $var 是外部$var的同名引用或指標。 (錯誤:是個別名引用而已,非指標!!!)
舉例說明一下:
php $GAOBAL[]的使用:
01 <?php 02 $var1 = 1; 03 $var2 = 2; 04 function test() { 05 $GLOBALS['var2'] = &$GLOBALS['var1']; 06 } 07 08 test(); 09 echo $var2; 10 ?>
正常列印結果為1
php global的使用:
01 <?php 02 $var1 = 1; 03 $var2 = 2; 04 05 function test(){ 06 global $var1, $var2; 07 $var2 = &$var1; 08 echo $var2; 09 $var2 = 'qianyunlai.com'; 10 } 11 12 test(); // 输出 1 13 echo $var2; // 输出 2 14 echo $var1; // 输出 qianyunlai.com 15 ?>
test()函數中的$var1,$va2都是局部變量,只不過是加了global關鍵字後,分別引用指向全域變數$ var1,$va2了,當 $var2 = &$var1; 時,局部變數$var2不再指向全域變數$val2,而重新指向全域變數$var1,換句話說,局部變數$var2的改變,不會再影響到全域變數$val2,而會影響到重新指向的全域變數$val1。
我們再來看一個例子吧。
1 <?php 2 $var1 = 1; 3 function test(){ 4 unset($GLOBALS['var1']); 5 } 6 test(); 7 echo $var1; 8 ?>
因為$var1被刪除了,所以什麼東西都沒有列印。
01 <?php 02 $var1 = 1; 03 04 function test(){ 05 global $var1; 06 unset($var1); 07 } 08 09 test(); 10 echo $var1; 11 ?>
意外的列印了1。
證明刪除的只是別名,$GLOBALS['var']的引用,起本身的值並沒有受到任何的改變。
明白了吧?
也就是說 global $var 其實是$var = &$GLOBALS['var']。呼叫外部變數的一個別名而已。
PHP中global和$GLOBALS不只是寫法不一樣以為,兩者的差別還是很大的,在實際應用中需要注意!
先看下面的例子:
1 <?php 2 $id = 1; 3 function test() { 4 global $id; 5 unset($id); 6 } 7 test(); 8 echo($id); // 输出 1 9 ?>
引用定位
許多PHP的語法結構是透過引用機制實現的,所以上述有關引用綁定的一切也都適用於這些結構。一些結構,例如引用傳遞和引用返回,已經在上面提到了。其它使用引用的結構有:
當用 global $var 宣告一個變數時實際上建立了一個到全域變數的參考。也就是說和這樣做是相同的:
01 <?php 02 $GLOBALS["var1"] = 1; 03 $var = &$GLOBALS["var1"]; 04 unset($var); 05 echo $GLOBALS['var1']; //输出1 06 //############################################ 07 $GLOBALS["var1"] = 1; 08 $var = &$GLOBALS["var1"]; 09 unset($GLOBALS['var1']); 10 echo $var; //输出1 11 //############################################ 12 //如果写成如下,则会出错 13 $GLOBALS["var"] = 1; 14 $var = &$GLOBALS["var"]; 15 unset($GLOBALS['var']); 16 echo $var; //脚本没法执行 17 //########################################### 18 ?>
這意味著,例如,unset $var 不會 unset 全域變數。
unset只是把只是斷開了變數名稱和變數內容之間的綁定。這並不意味著變數內容被銷毀了。
使用isset($var)的時候回傳 false。 $this在一個物件的方法中,$this 永遠是呼叫它的物件的引用。
如果在一個函數內部給一個宣告為 global 的變數賦於一個引用,則引用只在函數內部可見。
可以透過使用 $GLOBALS 陣列來避免這一點。
例 在函數內引用全域變數:
01 <?php 02 $var1 = "Example variable"; 03 $var2 = ""; 04 05 function global_references($use_globals) { 06 global $var1, $var2; 07 if (!$use_globals) { 08 $var2 = &$var1; // visible only inside the function 09 } else { 10 $GLOBALS["var2"] = &$var1; // visible also in global context 11 } 12 } 13 14 global_references(false); 15 echo "var2 is set to '$var2'\n"; // var2 is set to '' 16 global_references(true); 17 echo "var2 is set to '$var2'\n"; // var2 is set to 'Example variable' 18 ?>
把 global $var; 當成是 $var = &$GLOBALS['var']; 的簡寫。所以 如果將其它引用賦給 $var, 只改變了本地變數的引用。
如前所述,引用不是指標。這意味著下面的結構不會產生預期的效果:
1 <?php 2 $bar = 3; 3 function foo(&$var) { 4 $GLOBALS["baz"] = 5; 5 $var = &$GLOBALS["baz"]; 6 } 7 foo($bar); 8 echo $bar;//输出3 9 ?>
這將使foo 函數中的$var 變數在函數呼叫時和$bar 綁定在一起,但接著又被重新綁定到了$GLOBALS["baz"] 上面。
不可能透過引用機制將$bar 在函數呼叫範圍內綁定到別的變數上面,因為在函數foo 中並沒有變數$bar(它被表示為$var,但是$var 只有變數內容而沒有呼叫符號表中的名字到值的綁定)。可以使用引用返回來引用被函數選擇的變數。
引用php手冊的$GLOBALS的解釋:
Global 變數:$GLOBALS,注意: $GLOBALS 在 PHP 3.0.0 及以後版本中適用。
由所有已定義全域變數所組成的陣列。變數名就是該數組的索引。這是一個“superglobal”,或者可以描述為自動全域變數。
也就是說上面程式碼中的$var1和$GLOBALS['var1']是指的相同變量,而不是2個不同的變數!
如果在一個函數內部給一個宣告為 global 的變數賦於一個引用,則引用只在函數內部可見。可以透過使用 $GLOBALS 陣列來避免這一點。
我們都知道php中的函數所產生的變數都是函數的私有變量,那麼global關鍵字產生的變數也肯定逃不出這個規則,global在函數產生一個指向函數外部變數的別名變量,而不是真正的函數外部變量,一但改變了別名變量的指向地址,就會發生一些意料不到情況,$GLOBALS[]確確實實調用是外部的變量,函數內外會始終保持一致。
01 <?php 02 $a = 1; 03 $b = 2; 04 function Sum() { 05 global $a, $b; 06 $b = $a + $b; 07 } 08 Sum(); 09 echo $b; 10 ?>
輸出將是 “3″。在函數中申明 了全域變數 $a 和 $b,任何變數的所有引用變數都會指向到全域變數。
怎麼不是2呢,在函數外部不是不影響嗎,請注意$b在函數中並沒有透過引用修改,而是修改的$b指向物理記憶體的值,因此外部輸入為3。
相關建議:
以上是php中global與$GLOBAL的區別分析的詳細內容。更多資訊請關注PHP中文網其他相關文章!

PHPSession失效的原因包括配置錯誤、Cookie問題和Session過期。 1.配置錯誤:檢查並設置正確的session.save_path。 2.Cookie問題:確保Cookie設置正確。 3.Session過期:調整session.gc_maxlifetime值以延長會話時間。

在PHP中調試會話問題的方法包括:1.檢查會話是否正確啟動;2.驗證會話ID的傳遞;3.檢查會話數據的存儲和讀取;4.查看服務器配置。通過輸出會話ID和數據、查看會話文件內容等方法,可以有效診斷和解決會話相關的問題。

多次調用session_start()會導致警告信息和可能的數據覆蓋。 1)PHP會發出警告,提示session已啟動。 2)可能導致session數據意外覆蓋。 3)使用session_status()檢查session狀態,避免重複調用。

在PHP中配置會話生命週期可以通過設置session.gc_maxlifetime和session.cookie_lifetime來實現。 1)session.gc_maxlifetime控制服務器端會話數據的存活時間,2)session.cookie_lifetime控制客戶端cookie的生命週期,設置為0時cookie在瀏覽器關閉時過期。

使用數據庫存儲會話的主要優勢包括持久性、可擴展性和安全性。 1.持久性:即使服務器重啟,會話數據也能保持不變。 2.可擴展性:適用於分佈式系統,確保會話數據在多服務器間同步。 3.安全性:數據庫提供加密存儲,保護敏感信息。

在PHP中實現自定義會話處理可以通過實現SessionHandlerInterface接口來完成。具體步驟包括:1)創建實現SessionHandlerInterface的類,如CustomSessionHandler;2)重寫接口中的方法(如open,close,read,write,destroy,gc)來定義會話數據的生命週期和存儲方式;3)在PHP腳本中註冊自定義會話處理器並啟動會話。這樣可以將數據存儲在MySQL、Redis等介質中,提升性能、安全性和可擴展性。

SessionID是網絡應用程序中用來跟踪用戶會話狀態的機制。 1.它是一個隨機生成的字符串,用於在用戶與服務器之間的多次交互中保持用戶的身份信息。 2.服務器生成並通過cookie或URL參數發送給客戶端,幫助在用戶的多次請求中識別和關聯這些請求。 3.生成通常使用隨機算法保證唯一性和不可預測性。 4.在實際開發中,可以使用內存數據庫如Redis來存儲session數據,提升性能和安全性。

在無狀態環境如API中管理會話可以通過使用JWT或cookies來實現。 1.JWT適合無狀態和可擴展性,但大數據時體積大。 2.Cookies更傳統且易實現,但需謹慎配置以確保安全性。


熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

Video Face Swap
使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱門文章

熱工具

SublimeText3漢化版
中文版,非常好用

SAP NetWeaver Server Adapter for Eclipse
將Eclipse與SAP NetWeaver應用伺服器整合。

WebStorm Mac版
好用的JavaScript開發工具

SublimeText3 Linux新版
SublimeText3 Linux最新版

MinGW - Minimalist GNU for Windows
這個專案正在遷移到osdn.net/projects/mingw的過程中,你可以繼續在那裡關注我們。 MinGW:GNU編譯器集合(GCC)的本機Windows移植版本,可自由分發的導入函式庫和用於建置本機Windows應用程式的頭檔;包括對MSVC執行時間的擴展,以支援C99功能。 MinGW的所有軟體都可以在64位元Windows平台上運作。