函数参数传递机制问题在本质上是调用函数(过程)和被调用函数(过程)在调用发生时进行通信的方法问题。基本的参数传递机制有两种:值传递和引用传递。以下讨论称调用其他函数的函数为主调函数,被调用的函数为被调函数。
传值:把实参传给形参,改变形参值不影响实参值。
传地址:该方式传递值的方式是一种地址传递,传递后的实参和形参均指向一个地址。改变一个量,另一个量也随着改变。
传引用:真正以地址方式传递参数,该方式传递后,形参和实参都是同一个对象;只是名字不同。改变一个量,另外一个量也同时改变
unset——销毁指定的变量 或 释放给定的变量
void unset ( mixed var [, mixed var [, ...]] )
unset() 在函数中的行为会依赖于想要销毁的变量的类型而有所不同。
例子1 unset()使用方式
1 <?php 2 // 销毁单个变量 3 unset ($foo); 4 5 // 销毁单个数组元素 6 unset ($bar[‘quux‘]); 7 8 // 销毁一个以上的变量 9 unset ($foo1, $foo2, $foo3); 10 ?>
如果在函数中 unset() 一个全局变量,则只是局部变量被销毁,而在调用环境中的变量将保持调用 unset() 之前一样的值。
1 <?php 2 function destroy_foo() { 3 global $foo; 4 unset($foo); 5 } 6 7 $foo = ‘bar‘; 8 destroy_foo(); 9 echo $foo; 10 ?>
输出结果
1 bar
如果如果您想在函数中 unset() 一个全局变量,可使用 $GLOBALS 数组来实现
1 <?php 2 function foo() 3 { 4 unset($GLOBALS[‘bar‘]); 5 } 6 7 $bar = "something"; 8 foo(); 9 ?>
如果在函数中 unset() 一个通过引用传递的变量,则只是局部变量被销毁,而在调用环境中的变量将保持调用 unset() 之前一样的值。
1 <?php 2 function foo(&$bar) { 3 unset($bar); 4 $bar = "blah"; 5 } 6 7 $bar = ‘something‘; 8 echo "$bar\n"; 9 10 foo($bar); 11 echo "$bar\n"; 12 ?>
以上例程会输出:
1 something 2 something
如果在函数中 unset() 一个静态变量,那么在函数内部此静态变量将被销毁。但是,当再次调用此函数时,此静态变量将被复原为上次被销毁之前的值。
1 <?php 2 function foo() 3 { 4 static $bar; 5 $bar++; 6 echo "Before unset: $bar, "; 7 unset($bar); 8 $bar = 23; 9 echo "after unset: $bar\n"; 10 } 11 12 foo(); 13 foo(); 14 foo(); 15 ?>
以上例程会输出:
1 Before unset: 1, after unset: 23 2 Before unset: 2, after unset: 23 3 Before unset: 3, after unset: 23
注释:
Note: 因为是一个语言构造器而不是一个函数,不能被 可变函数 调用。
Note:
It is possible to unset even object properties visible in current context.
Note:
在 PHP 5 之前无法在对象里销毁 $this。
Note:
在 unset() 一个无法访问的对象属性时,如果定义了 __unset() 则对调用这个重载方法。
原文:http://www.cnblogs.com/gengyi/p/6368042.html