多多色-多人伦交性欧美在线观看-多人伦精品一区二区三区视频-多色视频-免费黄色视屏网站-免费黄色在线

國內最全IT社區平臺 聯系我們 | 收藏本站
阿里云優惠2
您當前位置:首頁 > php開源 > php教程 > PHP Global與$GLOBALS變量作用域與區別

PHP Global與$GLOBALS變量作用域與區別

來源:程序員人生   發布時間:2013-11-25 13:12:59 閱讀次數:3154次

在php中變量有很多種如普通的變量及全局變量(Global與$GLOBALS),本文章來給大家介紹在php中Global與$GLOBALS的用法區別.

Global,全局變量

PHP Global變量在實際應用中會發現許多問題需要我們不斷的去完善處理.我們在這篇文章中就針對PHP Global變量出現的問題給出了一些具體的解決辦法,PHP hack的使用技巧詳解,代碼實現PHP GTK寫文本查看器,網站開發中PHP語言優缺點.

如何正確實現PHP function函數擴展

PHP error_log()函數處理錯誤日志

1:PHP Global變量的作用是定義全局變量,但是這個全局變量不是應用于整個網站,而是應用于當前頁面,包括include或require的所有文件

實例代碼如下:

  1. $a=123;  
  2.  
  3. function aa()  
  4. {  
  5. Global $a;   
  6. //如果不把$a定義為global變量 
  7. ,函數體內是不能訪問$a的  
  8. echo $a;  
  9. }  
  10. aa(); 

總結:

在函數體內定義的PHP Global變量,函數體外可以使用,在函數體外定義的global變量不能在函數體內使用,

實例代碼如下:

  1. $glpbal $a;   
  2. $a=123;    
  3. function f()   
  4. {   
  5. echo $a//錯誤,   
  6. }  

再看看下面一例,實例代碼如下:

  1. function f()   
  2.  
  3. {   
  4. global $a;  $a=123;   
  5. }    
  6. f();   
  7. echo $a
  8. //正確,可以使用 

2:PHP Global變量問題解析:

question:我在config.inc.php中定義了一些變量($a),在別的文件中函數外部 include("config.inc.php"),函數內部需要使用這些變量$a,如果沒有聲明的話,echo $a是打印不出來任何東西的.因此聲明global $a,但是有很多函數和很多變量.總不能不斷重復的這樣聲明吧?有什么好的解決辦法,請指點.

answer1:先在config.inc.php里定義常量:define(常量名,常量值),再在其他需要用到的地方require 'config.inc.php',然后就能在這個文件里直接使用這個常量了.

answer2:我也有個辦法,就是定義數組,如$x[a],$x,那樣就只要聲明global $x一個了.

answer3:我試了你的這個方法,不行啊.

answer4:改你的php.ini文件.

設置PHP Global變量 為 on,下面我們看看復雜點的:

實例代碼如下:

  1. //A.php 文件 
  2. function Test_Global() 
  3.     include 'B.php'
  4.     Test(); 
  5. $a = 0 ; 
  6. Test_Global(); 
  7. echo $a
  8. ?> 
  9. //B.php 文件 
  10. function Test() 
  11.    global $a;//申明函數體Sum內使用的$a變量為global全局變量 
  12.    $a =1; 
  13. ?> 

為什么輸出的卻是0?!!

在用戶自定義函數中,一個局部函數范圍將被引入.任何用于函數內部的變量按缺省情況將被限制在局部函數范圍內(包括include 和 require 導入的文件內的變量)!

解釋:A.php文件的內Test_Global是定義好的第三方函數,該函數用include導入了B.php文件內的$a的global全局變量,所以$a被限制在Test_Global局部函數范圍內,所以B.php文件內的$a的作用范圍都在Test_Global內,而不是作用了整個A.php內….

解決方案:

1. 沖出局部函數實例代碼如下:

  1. //A.php 文件 
  2. function Test_Global() 
  3.     Test(); 
  4. include 'B.php'//將include 從局部Test_Global函數中移出 
  5. $a = 0 ; 
  6. Test_Global(); 
  7. echo $a
  8. ?> 
  9. //B.php 文件 
  10. function Test() 
  11.     global $a
  12.     $a =1; 
  13. ?> 

global和$GLOBALS的區別

php中global和$GLOBALS不僅僅是寫法不一樣以為,2者的區別還是很大的,在實際應用中需要注意!

先看下面的實例代碼:

  1.  // 例子1 
  2.  function test_global() { 
  3.    global $var1$var2
  4.    $var2 =& $var1
  5.  } 
  6.  function test_globals() { 
  7.    $GLOBALS['var3'] =& $GLOBALS['var1']; 
  8.  } 
  9.  $var1 = 5; 
  10.  $var2 = $var3 = 0; 
  11.  test_global(); 
  12.  print $var2 .”n”; 
  13.  test_globals(); 
  14.  print $var3 .”n”; 
  15.  ?>  

執行結果為:0 5

怎么會這樣呢?不應該是2個5嗎?怎么會出現1個0和1個5呢?

恩,我們保留以上問題,深入分析$GLOBALS和global的原理!我們都知道變量其實是相應物理內存在代碼中的”代號”而已引用php手冊的$GLOBALS的解釋:

Global 變量:$GLOBALS,注意: $GLOBALS 在 PHP 3.0.0 及以后版本中適用.由所有已定義全局變量組成的數組.變量名就是該數組的索引.這是一個“superglobal”,或者可以描述為自動全局變量.也就是說上面代碼中的$var1和$GLOBALS['var1']是指的同一變量,而不是2個不同的變量!下面來分析global到底做了什么?

引用php手冊的global的解釋:

如果在一個函數內部給一個聲明為 global 的變量賦于一個引用,該引用只在函數內部可見.可以通過使用 $GLOBALS 數組避免這一點.我們都知道php中的函數所產生的變量都是函數的私有變量,那么global關鍵字產生的變量也肯定逃不出這個規則,為什么這么說呢,

請看下面的代碼:

  1.  // 例子2 
  2.  function test() { 
  3.    global $a
  4.    unset($a); 
  5.  } 
  6.  $a = 1; 
  7.  test(); 
  8.  print $a
  9.  ?>  

執行結果為:1

為什么會輸出1呢?不是已經把$a給unset了嗎?unset失靈了?php的bug?

都不是,其實unset起作用了,是把test函數中的$a給unset掉了,可以在函數test()中加入print $a;來測試!

接著回到上面的例子1,看test_global中的這一代碼“$var2 =& $var1;”,上面是一個引用賦值運算,也就是$var2將指向var1所指向的物理內存地址,所以例子1執行過test_global函數以后,變量的變化只在函數的局部產生效應,在函數外部$var2的指向物理內存地址并沒有變化,還是它自己.此時,就能理解為什么例子1執行完以后,$var2是0,而$var3是5了!

所以我們得出一個結論,在函數中global和$GLOBALS[]的區別在于:

global在函數產生一個指向函數外部變量的別名變量,而不是真正的函數外部變量,一但改變了別名變量的指向地址,就會發生一些意料不到情況,例如例子1.

$GLOBALS[]確確實實調用是外部的變量,函數內外會始終保持一致,可以對照下面兩個列子再加深下印象:

global:

實例代碼如下:

  1. function myfunction(){ 
  2.     global $bar
  3.     unset($bar); 
  4. $bar=”someting”; 
  5. myfunction(); 
  6. echo $bar
  7. ?> 

輸出:someting

  1. $GLOBALS[]: 
  2.     function foo() 
  3.     unset($GLOBALS['bar']); 
  4. $bar = “something”; 
  5. foo(); 
  6. echo $bar
  7. ?> 

輸出:空

當按照上面的思路理解后,碰到下面的情況是不是又有些暈呢?

實例代碼如下:

  1. $a = 1; 
  2. $b = 2; 
  3. function Sum() 
  4.    global $a$b
  5.    $b = $a + $b
  6. Sum(); 
  7. echo $b
  8. ?> 

輸出將是 “3″.在函數中申明了全局變量 $a 和 $b,任何變量的所有引用變量都會指向到全局變量.

怎么不是2呢,在函數外部不是不影響嗎,請注意$b在函數中并沒有通過引用修改,而是修改的$b指向物理內存的值,因此外部輸入為3.

php中global和$GLOBALS不僅僅是寫法不一樣以為,2者的區別還是很大的,在實際應用中需要注意!

先看下面的PHP代碼例子:

  1.  // 例子1  
  2.  function test_global() {  
  3.    global $var1$var2;  
  4.    $var2 =& $var1;  
  5.  }  
  6.  function test_globals() {  
  7.    $GLOBALS['var3'] =& $GLOBALS['var1'];  
  8.  }  
  9.  $var1 = 5;  
  10.  $var2 = $var3 = 0;  
  11.  test_global();  
  12.  print $var2 .”n”;  
  13.  test_globals();  
  14.  print $var3 .”n”;  
  15.  ?>   

執行結果為:0 5

怎么會這樣呢?不應該是2個5嗎?怎么會出現1個0和1個5呢?

恩,我們保留以上問題,深入分析$GLOBALS和global的原理!我們都知道變量其實是相應物理內存在代碼中的“代號“而已,引用php手冊的$GLOBALS的解釋:

Global 變量:$GLOBALS,注意: $GLOBALS 在 PHP 3.0.0 及以后版本中適用.

由所有已定義全局變量組成的數組.變量名就是該數組的索引.這是一個“superglobal”,或者可以描述為自動全局變量.也就是說上面代碼中的$var1和$GLOBALS['var1']是指的同一變量,而不是2個不同的變量!

下面來分析global到底做了什么?

引用php手冊的global的解釋:

如果在一個函數內部給一個聲明為 global 的變量賦于一個引用,該引用只在函數內部可見.可以通過使用 $GLOBALS 數組避免這一點.我們都知道php中的函數所產生的變量都是函數的私有變量,那么global關鍵字產生的變量也肯定逃不出這個規則,為什么這么說呢,看下面的代碼:

實例代碼如下:

  1.  // 例子2  
  2.  function test() {  
  3.    global $a;  
  4.    unset($a);  
  5.  }  
  6.    
  7.  $a = 1;  
  8.  test();  
  9.  print $a;  
  10.  ?>   

執行結果為:1

為什么會輸出1呢?不是已經把$a給unset了嗎?unset失靈了?php的bug?

都不是,其實unset起作用了,是把test函數中的$a給unset掉了,可以在函數test()中加入print $a;來測試!

接著回到上面的例子1,看test_global中的這一代碼“$var2 =& $var1;”,上面是一個引用賦值運算,也就是$var2將指向var1所指向的物理內存地址,所以例子1執行過test_global函數以后,變量的變化只在函數的局部產生效應,在函數外部$var2的指向物理內存地址并沒有變化,還是它自己.

此時,就能理解為什么例子1執行完以后,$var2是0,而$var3是5了!

所以我們得出一個結論,在函數中global和$GLOBALS[]的區別在于:

global在函數產生一個指向函數外部變量的別名變量,而不是真正的函數外部變量,一但改變了別名變量的指向地址,就會發生一些意料不到情況,例如例子1.

$GLOBALS[]確確實實調用是外部的變量,函數內外會始終保持一致,可以對照下面兩個列子再加深下印象:

global:

實例代碼如下:

  1. function myfunction(){ 
  2.     global $bar
  3.     unset($bar); 
  4. $bar=”someting”; 
  5. myfunction(); 
  6. echo $bar
  7. ?> 

輸出:someting

實例代碼如下:

  1. $GLOBALS[]: 
  2.     function foo() 
  3.     unset($GLOBALS['bar']); 
  4. $bar = “something”; 
  5. foo(); 
  6. echo $bar
  7. ?> 

輸出:空

當按照上面的思路理解后,碰到下面的情況是不是又有些暈呢?

實例代碼如下:

  1. $a = 1; 
  2. $b = 2; 
  3. function Sum() 
  4.    global $a$b
  5.    $b = $a + $b
  6. Sum(); 
  7. echo $b
  8. ?> 

輸出將是 “3″.在函數中申明了全局變量 $a 和 $b,任何變量的所有引用變量都會指向到全局變量.

怎么不是2呢,在函數外部不是不影響嗎,請注意$b在函數中并沒有通過引用修改,而是修改的$b指向物理內存的值,因此外部輸入為3


生活不易,碼農辛苦
如果您覺得本網站對您的學習有所幫助,可以手機掃描二維碼進行捐贈
程序員人生
------分隔線----------------------------
分享到:
------分隔線----------------------------
關閉
程序員人生
主站蜘蛛池模板: 日韩欧美色 | 川上优最新中文字幕不卡 | 日韩视频在线观看一区二区 | 欧美在线播放成人免费 | 亚洲国产日韩欧美一区二区三区 | 男女啪啦猛视频免费 | 亚洲 日本 欧美 | 久久久亚洲欧洲国产 | 日本青草视频 | 琪琪在线观看 | 成人xxxxx| 国产国语videosex | 中文字幕视频免费在线观看 | 中文字幕日本一本二本三区 | 三级做爰大爽长视频在线观看 | 日韩a视频| 精品国产三级v | 欧美超清free videos | 日本不卡视频在线 | 久久免费大片 | 国产成人久久一区二区三区 | 女人18毛片a级毛片一区二区 | 乡下女色又黄一级毛片 | 欧美色欧美亚洲另类二区精品 | 国产精品久久亚洲一区二区 | 欧美亚洲一区二区三区 | 欧美精品日韩一区二区三区 | 91不卡在线精品国产 | 无码精品一区二区三区免费视频 | 永久免费看片 | 亚洲成人在线视频观看 | 中文国产成人精品久久96 | 午夜精品久久久久久久久 | 亚洲精品一级片 | 国产欧美一区二区另类精品 | 中文字幕乱码中文 | 男人天堂亚洲 | 成人eeuss影院在线观看 | 欧美一级毛片美99毛片 | 欧美另类小说乱小说 | 国产成人一区免费观看 |