Heim  >  Artikel  >  Backend-Entwicklung  >  PHP中的引用,“&”解释

PHP中的引用,“&”解释

WBOY
WBOYOriginal
2016-07-25 08:52:011037Durchsuche
  1. $a =& $b
  2. ?>
复制代码

这意味着 $a 和 $b 指向了同一个变量。 注: $a 和 $b 在这里是完全相同的,这并不是 $a 指向了 $b 或者相反,而是 $a 和 $b 指向了同一个地方。 同样的语法可以用在函数中,它返回引用,以及用在 new 运算符中(PHP 4.0.4 以及以后版本):

  1. $bar =& new fooclass();
  2. $foo =& find_var ($bar);
  3. ?>
复制代码

注: 不用 & 运算符导致对象生成了一个拷贝。如果你在类中用 $this,它将作用于该类当前的实例。没有用 & 的赋值将拷贝这个实例(例如对象)并且 $this 将作用于这个拷贝上,这并不总是想要的结果。由于性能和内存消耗的问题,通常你只想工作在一个实例上面。

尽管你可以用 @ 运算符来关闭构造函数中的任何错误信息,例如用 @new,但用 &new 语句时这不起效果。这是 Zend 引擎的一个限制并且会导致一个解析错误。

引用做的第二件事是用引用传递变量。这是通过在函数内建立一个本地变量并且该变量在呼叫范围内引用了同一个内容来实现的。例如:

  1. function foo (&$var)

  2. {
  3. $var++;
  4. }
  5. $a=5;

  6. foo ($a);
  7. ?>
复制代码

将使 $a 变成 6。这是因为在 foo 函数中变量 $var 指向了和 $a 指向的同一个内容。更多详细解释见引用传递。 引用做的第三件事是引用返回。

引用不是什么 如前所述,引用不是指针。这意味着下面的结构不会产生你预期的效果:

  1. function foo (&$var)
  2. {
  3. $var =& $GLOBALS[ "baz "];
  4. }
  5. foo($bar);
  6. ?>
复制代码

这将使 foo 函数中的 $var 变量在函数调用时和 $bar 绑定在一起,但接着又被重新绑定到了 $GLOBALS[ "baz "] 上面。不可能通过引用机制将 $bar 在函数调用范围内绑定到别的变量上面,因为在函数 foo 中并没有变量 $bar(它被表示为 $var,但是 $var 只有变量内容而没有调用符号表中的名字到值的绑定)。

引用传递 你可以将一个变量通过引用传递给函数,这样该函数就可以修改其参数的值。语法如下:

  1. function foo (&$var)

  2. {
  3. $var++;
  4. }
  5. $a=5;

  6. foo ($a);
  7. // $a is 6 here
  8. ?>
复制代码

注意在函数调用时没有引用符号 - 只有函数定义中有。光是函数定义就足够使参数通过引用来正确传递了。

以下内容可以通过引用传递: 变量,例如 foo($a)

New 语句,例如 foo(new foobar())

从函数中返回的引用,例如:

  1. function &bar()
  2. {
  3. $a = 5;
  4. return $a;
  5. }
  6. foo(bar());
  7. ?>
复制代码

详细解释见引用返回。

任何其它表达式都不能通过引用传递,结果未定义。例如下面引用传递的例子是无效的:

  1. function bar() // Note the missing &

  2. {
  3. $a = 5;
  4. return $a;
  5. }
  6. foo(bar());
  7. foo($a = 5) // 表达式,不是变量

  8. foo(5) // 常量,不是变量
  9. ?>
复制代码

这些条件是 PHP 4.0.4 以及以后版本有的。

引用返回 引用返回用在当你想用函数找到引用应该被绑定在哪一个变量上面时。当返回引用时,使用此语法:

  1. function &find_var ($param)

  2. {
  3. return $found_var;
  4. }
  5. $foo =& find_var ($bar);

  6. $foo-> x = 2;
  7. ?>
复制代码

本例中 find_var 函数所返回的对象的属性将被设定(译者:指的是 $foo-> x = 2; 语句),而不是拷贝,就和没有用引用语法一样。

注: 和参数传递不同,这里必须在两个地方都用 & 符号 - 来指出返回的是一个引用,而不是通常的一个拷贝,同样也指出 $foo 是作为引用的绑定,而不是通常的赋值。

取消引用 当你 unset 一个引用,只是断开了变量名和变量内容之间的绑定。这并不意味着变量内容被销毁了。例如:

  1. $a = 1;
  2. $b =& $a;
  3. unset ($a);
  4. ?>
复制代码

不会 unset $b,只是 $a。

再拿这个和 Unix 的 unlink 调用来类比一下可能有助于理解。

引用定位 许多 PHP 的语法结构是通过引用机制实现的,所以上述有关引用绑定的一切也都适用于这些结构。一些结构,例如引用传递和返回,已经在上面提到了。其它使用引用的结构有:

global 引用 当用 global $var 声明一个变量时实际上建立了一个到全局变量的引用。也就是说和这样做是相同的:

  1. $var =& $GLOBALS[ "var "];
  2. ?>
复制代码

这意味着,例如,unset $var 不会 unset 全局变量。

$this 在一个对象的方法中,$this 永远是调用它的对象的引用。 您可能感兴趣的文章: php引用传值的详细介绍 通过实例理解php中传值与传引用的区别 通过实例看php地址引用的效率问题 有关php引用地址改变变量值的问题



Stellungnahme:
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn