如果对于变量和常量的定义,你会注意几个方面呢?你可能会想到:
•如何定义变量,它和C# 等语言有什么不同呢?
•变量区分大小写吗?
•PHP的变量还有其他重要的吗?
•常量和变量的定义一样吗?
分别讲述吧。
1.如何定义变量,它和C# 等语言有什么不同呢?
PHP 中的变量用一个美元符号后面跟变量名来表示。变量名是区分大小写的。例如:
代码如下 | 复制代码 |
<?php $var='Jim'; $VAR='Kimi; echo "$var,$VAR";//输出“Jim,Kimi" ?> |
你可能还关心变量的命名,其实和大多数语言一样。
2. 变量区分大小写吗?
如 1里说的,区分大小写。
注意,需要说明的一点是自PHP4以来,引入了引用赋值的概念,其实和多数语言的引用类似,不过我觉得最类似的是C/C++.因为它也用到了"&"符号。
例如:
代码如下 | 复制代码 |
1 <?php 2 $foo = 'Bob'; // 赋值'Bob'给foo 3 $bar = &$foo; // 通过$bar引用.注意&符号 4 $bar = "My name is $bar"; // 修改 $bar 5 echo $bar; 6 echo $foo; // $foo 也修改了. 7 ?> |
和其他语言一样,只能对有变量名的变量才可以引用
php中的可变变量说白了,就是拿一个变量的值解析成一个变量名,去读那个变量名的值。实例:
代码如下 | 复制代码 |
<?php |
注意:可变变量不能应用于$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> |
变量作用域 .
变量范围
变量的范围即它定义的上下文背景(译者:说白了,也就是它的生效范围)。大部分的 PHP 变量只有一个单独的范围。这个单独的范围跨度同样包含了 include 和 require 引入的文件。范例:
代码如下 | 复制代码 |
<?php $a = 1; include "b.inc"; ?> |
这里变量 $a 将会在包含文件 b.inc 中生效。但是,在用户自定义函数中,一个局部函数范围将被引入。任何用于函数内部的变量按缺省情况将被限制在局部函数范围内。范例:
代码如下 | 复制代码 |
<?php $a = 1; /* global scope */ function Test() Test(); |
这个脚本不会有任何输出,因为 echo 语句引用了一个局部版本的变量 $a,而且在这个范围内,它并没有被赋值。你可能注意到 PHP 的全局变量和 C 语言有一点点不同,在 C 语言中,全局变量在函数中自动生效,除非被局部变量覆盖。这可能引起一些问题,有些人可能漫不经心的改变一个全局变量。PHP 中全局变量在函数中使用时必须申明为全局。
The global keyword
首先,一个使用 global 的例子:
例子 12-1. 使用 global
代码如下 | 复制代码 |
<?php $a = 1; $b = 2; function Sum() $b = $a + $b; Sum(); |
以上脚本的输出将是 "3"。在函数中申明了全局变量 $a 和 $b,任何变量的所有引用变量都会指向到全局变量。对于一个函数能够申明的全局变量的最大个数,PHP 没有限制。
在全局范围内访问变量的第二个办法,是用特殊的 PHP 自定义 $GLOBALS 数组。前面的例子可以写成:
例子 12-2. 使用 $GLOBALS 替代 global
代码如下 | 复制代码 |
<?php $a = 1; $b = 2; function Sum() Sum(); |
在 $GLOBALS 数组中,每一个变量为一个元素,键名对应变量名,值变量的内容。$GLOBALS 之所以在全局范围内存在,是因为 $GLOBALS 是一个超全局变量。以下范例显示了超全局变量的用处:
例子 12-3. 演示超全局变量和作用域的例子
代码如下 | 复制代码 |
<?php function test_global() { // 大多数的预定义变量并不 "super",它们需要用 'global' 关键字来使它们在函数的本地区域中有效。 global $HTTP_POST_VARS; print $HTTP_POST_VARS['name']; // Superglobals 在任何范围内都有效,它们并不需要 'global' 声明。Superglobals 是在 PHP 4.1.0 引入的。 |
使用静态变量
变量范围的另一个重要特性是静态变量(static variable)。静态变量仅在局部函数域中存在,但当程序执行离开此作用域时,其值并不丢失。看看下面的例子:
例子 12-4. 演示需要静态变量的例子
代码如下 | 复制代码 |
<?php function Test () { $a = 0; echo $a; $a++; } ?> |
本函数没什么用处,因为每次调用时都会将 $a 的值设为 0 并输出 "0"。将变量加一的 $a++ 没有作用,因为一旦退出本函数则变量 $a 就不存在了。要写一个不会丢失本次计数值的计数函数,要将变量 $a 定义为静态的:
例子 12-5. 使用静态变量的例子
代码如下 | 复制代码 |
<?php function Test() { static $a = 0; echo $a; $a++; } ?> |
现在,每次调用 Test() 函数都会输出 $a 的值并加一。
静态变量也提供了一种处理递归函数的方法。递归函数是一种调用自己的函数。写递归函数时要小心,因为可能会无穷递归下去。必须确保有充分的方法来中止递归。一下这个简单的函数递归计数到 10,使用静态变量 $count 来判断何时停止:
例子 12-6. 静态变量与递归函数
代码如下 | 复制代码 |
<?php function Test() { static $count = 0; $count++; |
注: 静态变量可以按照上面的例子声明。如果在声明中用表达式的结果对其赋值会导致解析错误。
例子 12-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++; |
全局和静态变量的引用
在 Zend 引擎 1 代,驱动了 PHP4,对于变量的 static 和 global 定义是以 references 的方式实现的。例如,在一个函数域内部用 global 语句导入的一个真正的全局变量实际上是建立了一个到全局变量的引用。这有可能导致预料之外的行为,如以下例子所演示的:
代码如下 | 复制代码 |
<?php function test_global_ref() { global $obj; $obj = &new stdclass; } function test_global_noref() { test_global_ref(); |
执行以上例子会导致如下输出:
NULLobject(stdClass)(0) {}
类似的行为也适用于 static 语句。引用并不是静态地存储的:
代码如下 | 复制代码 |
<?php function &get_instance_ref() { static $obj; echo "Static object: "; function &get_instance_noref() { echo "Static object: "; $obj1 = get_instance_ref(); |
执行以上例子会导致如下输出:
Static object: NULLStatic object: NULLStatic object: NULLStatic object: object(stdClass)(1) { ["property"]=> int(1)}
上例演示了当把一个引用赋值给一个静态变量时,第二次调用 &get_instance_ref() 函数时其值并没有被记住