變量是php編程中必不可少的一種東西了,在php中變量為分全局變量與私有變量,下面來分享我對php變量的一些了解與用法,大家可參考參考.
如果對于變量和常量的定義,你會注意幾個方面呢?你可能會想到:
•如何定義變量,它和C# 等語言有什么不同呢?
•變量區分大小寫嗎?
•PHP的變量還有其他重要的嗎?
•常量和變量的定義一樣嗎?
分別講述吧.
1.如何定義變量,它和C# 等語言有什么不同呢?
PHP 中的變量用一個美元符號后面跟變量名來表示.變量名是區分大小寫的.例如:
實例代碼如下:
- <?php
- $var='Jim';
- $VAR='Kimi;
- echo "$var,$VAR";//輸出“Jim,Kimi"
- ?>
你可能還關心變量的命名,其實和大多數語言一樣.
2. 變量區分大小寫嗎?
如 1里說的,區分大小寫.
注意,需要說明的一點是自PHP4以來,引入了引用賦值的概念,其實和多數語言的引用類似,不過我覺得最類似的是C/C++.因為它也用到了"&"符號.
實例代碼如下:
- <?php
- $foo = 'Bob'; // 賦值'Bob'給foo
- $bar = &$foo; // 通過$bar引用.注意&符號
- $bar = "My name is $bar"; // 修改 $bar
- echo $bar;
- echo $foo; // $foo 也修改了.
- ?>
和其他語言一樣,只能對有變量名的變量才可以引用
php中的可變變量說白了,就是拿一個變量的值解析成一個變量名,去讀那個變量名的值.
實例代碼如下:
- <?php
- $a = "China"; //變量a
- $b = "a"; //變量b
- $China = "I'm Chinese !"; //變量China
- $f = "b"; //變量f
- echo $a."<br />"; //輸出 China
- echo $$a."<br />"; //輸出 I'm Chinese --這里像要當做可變變量解析,必須在前面多加一個$符號
- $a = "f"; //改變變量指向的名稱(這里就是可變變量的應用)
- echo $$a."<br />"; //經過上面指向變量f后輸出 b
- $a = "b"; //同上
- echo $$a."<br /><br />"; //輸出 a
- echo $b."<br />"; //輸出 a
- echo $$b."<br />"; //輸出 b
- echo $$$b."<br /><br />"; //輸出 a
- echo $f."<br />"; //輸出 b
- echo $$f."<br />"; //輸出 a
- echo $$$f."<br />"; //輸出 b
- echo $$$$f."<br /><br />"; //輸出 a
- $$a = "China"; //前面最后一個已經更改了變量為b所謂$$a=$b 也就是改變的$b的值
- echo $b."<br />"; //輸出 China
- echo $$b; //輸出 I'm Chinese
- ?>
注意:可變變量不能應用于$this和超全局變量 (php變量的作用域和其他高級編程語言有所不同.看代碼)
實例代碼如下:
- <?php
- $name = 'man';
- $$name = 'abc'; //如果事先沒有man這個變量.就新建一個man變量. 然后把abc賦值過去
- $$$name = 'def';
- echo $man."<br />"; //輸出abc
- echo $abc; //輸出def
- echo "<br /> <hr />";
- function show()
- {
- global $name; //這里的global并不是設置為全局變量.而是引用
- echo $name."<br />"; //輸出man
- }
- function showtwo()
- {
- //global $name;
- //echo $name."<br />";
- echo $GLOBALS['name']; //超全局變量數組
- }
- show();
- showtwo();
- ?>
變量函數:
實例代碼如下:
- <?php
- function b()
- {
- echo "這是B";
- }
- function c($name = "China") //設默認值
- {
- echo "這是$name";
- }
- $a = 'b';
- $a(); //找值所在的函數
- $a = 'c';
- $a(); ?>
可變變量的一個典型應用:
實例代碼如下:
- <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
- <html xmlns="http://www.w3.org/1999/xhtml">
- <head>
- <meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
- <title>無標題文檔</title>
- </head>
- <body>
- <div>
- <form action="#" method="post">
- <label>name: </label>
- <input type="text" name="name" /><br />
- <label>pwd : </label>
- <input type="text" name="pwd" /><br />
- <label>tag : </label>
- <input type="text" name="tag" /><br />
- <input type="submit" value="提交" />
- </form>
- </div>
- <?php
- foreach($_POST as $key=>$value)
- {
- //print_r($_POST);
- $$key = $value;
- }
- //extract($_POST); //從數組中將變量導入到當前的符號表 --自行查找php手冊
- echo $name."<br />";
- echo $pwd."<br />";
- echo $tag."<br />";
- ?>
- </body>
- </html>
變量作用域 .
變量范圍
變量的范圍即它定義的上下文背景(譯者:說白了,也就是它的生效范圍).大部分的 PHP 變量只有一個單獨的范圍.這個單獨的范圍跨度同樣包含了 include 和 require 引入的文件.范例:
實例代碼如下:
- <?php
- $a = 1;
- include "b.inc";
- ?>
這里變量 $a 將會在包含文件 b.inc 中生效.但是,在用戶自定義函數中,一個局部函數范圍將被引入.任何用于函數內部的變量按缺省情況將被限制在局部函數范圍內.范例:
實例代碼如下:
- <?php
- $a = 1; /* global scope */
- function Test()
- {
- echo $a; /* reference to local scope variable */
- }
- Test();
- ?>
這個腳本不會有任何輸出,因為 echo 語句引用了一個局部版本的變量 $a,而且在這個范圍內,它并沒有被賦值.你可能注意到 PHP 的全局變量和 C 語言有一點點不同,在 C 語言中,全局變量在函數中自動生效,除非被局部變量覆蓋.這可能引起一些問題,有些人可能漫不經心的改變一個全局變量.PHP 中全局變量在函數中使用時必須申明為全局.
The global keyword
首先,一個使用 global 的例子:
例子1. 使用 global
實例代碼如下:
- <?php
- $a = 1;
- $b = 2;
- function Sum()
- {
- global $a, $b;
- $b = $a + $b;
- }
- Sum();
- echo $b;
- ?>
以上腳本的輸出將是 "3".在函數中申明了全局變量 $a 和 $b,任何變量的所有引用變量都會指向到全局變量.對于一個函數能夠申明的全局變量的最大個數,PHP 沒有限制.
在全局范圍內訪問變量的第二個辦法,是用特殊的 PHP 自定義 $GLOBALS 數組.前面的例子可以寫成:
例子2. 使用 $GLOBALS 替代 global
實例代碼如下:
- <?php
- $a = 1;
- $b = 2;
- function Sum()
- {
- $GLOBALS["b"] = $GLOBALS["a"] + $GLOBALS["b"];
- }
- Sum();
- echo $b;
- ?>
在 $GLOBALS 數組中,每一個變量為一個元素,鍵名對應變量名,值變量的內容.$GLOBALS 之所以在全局范圍內存在,是因為 $GLOBALS 是一個超全局變量.以下范例顯示了超全局變量的用處:
例子3. 演示超全局變量和作用域的例子
實例代碼如下:
- <?php
- function test_global()
- {
- // 大多數的預定義變量并不 "super",它們需要用 'global' 關鍵字來使它們在函數的本地區域中有效.
- global $HTTP_POST_VARS;
- print $HTTP_POST_VARS['name'];
- // Superglobals 在任何范圍內都有效,它們并不需要 'global' 聲明.Superglobals 是在 PHP 4.1.0 引入的.
- print $_POST['name'];
- }
- ?>
使用靜態變量
變量范圍的另一個重要特性是靜態變量(static variable).靜態變量僅在局部函數域中存在,但當程序執行離開此作用域時,其值并不丟失.看看下面的例子:
例子4. 演示需要靜態變量的例子
實例代碼如下:
- <?php
- function Test ()
- {
- $a = 0;
- echo $a;
- $a++;
- }
- ?>
本函數沒什么用處,因為每次調用時都會將 $a 的值設為 0 并輸出 "0".將變量加一的 $a++ 沒有作用,因為一旦退出本函數則變量 $a 就不存在了.要寫一個不會丟失本次計數值的計數函數,要將變量 $a 定義為靜態的:
例子5. 使用靜態變量的例子
實例代碼如下:
現在,每次調用 Test() 函數都會輸出 $a 的值并加一.
例子6. 靜態變量與遞歸函數
實例代碼如下:
- <?php
- function Test()
- {
- static $count = 0;
- $count++;
- echo $count;
- if ($count < 10) {
- Test ();
- }
- $count--;
- }
- ?>
注: 靜態變量可以按照上面的例子聲明.如果在聲明中用表達式的結果對其賦值會導致解析錯誤.
例子7. 聲明靜態變量
實例代碼如下:
- <?php
- function foo(){
- static $int = 0; // correct
- static $int = 1+2; // wrong (as it is an expression)
- static $int = sqrt(121); // wrong (as it is an expression too)
- $int++;
- echo $int;
- }
- ?>
全局和靜態變量的引用
在 Zend 引擎 1 代,驅動了 PHP4,對于變量的 static 和 global 定義是以 references 的方式實現的.例如,在一個函數域內部用 global 語句導入的一個真正的全局變量實際上是建立了一個到全局變量的引用.這有可能導致預料之外的行為,如以下例子所演示的:
實例代碼如下:
- <?php
- function test_global_ref() {
- global $obj;
- $obj = &new stdclass;
- }
- function test_global_noref() {
- global $obj;
- $obj = new stdclass;
- }
- test_global_ref();
- var_dump($obj);
- test_global_noref();
- var_dump($obj);
- ?>
執行以上例子會導致如下輸出:
NULLobject(stdClass)(0) {}類似的行為也適用于 static 語句.引用并不是靜態地存儲的:
實例代碼如下:
- <?php
- function &get_instance_ref() {
- static $obj;
- echo "Static object: ";
- var_dump($obj);
- if (!isset($obj)) {
- // 將一個引用賦值給靜態變量
- $obj = &new stdclass;
- }
- $obj->property++;
- return $obj;
- }
- function &get_instance_noref() {
- static $obj;
- echo "Static object: ";
- var_dump($obj);
- if (!isset($obj)) {
- // 將一個對象賦值給靜態變量
- $obj = new stdclass;
- }
- $obj->property++;
- return $obj;
- }
- $obj1 = get_instance_ref();
- $still_obj1 = get_instance_ref();
- echo "/n";
- $obj2 = get_instance_noref();
- $still_obj2 = get_instance_noref();
- ?>
執行以上例子會導致如下輸出:
Static object: NULLStatic object: NULLStatic object: NULLStatic object: object(stdClass)(1) { ["property"]=> int(1)}
上例演示了當把一個引用賦值給一個靜態變量時,第二次調用 &get_instance_ref() 函數時其值并沒有被記住
新聞熱點
疑難解答