首頁 >php教程 >php手册 >php的变量范围、引用、对象引用、传递

php的变量范围、引用、对象引用、传递

WBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWB
WBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWB原創
2016-06-13 10:15:09838瀏覽

本文章介绍了php的变量范围、引用、对象引用、传递,有需要的朋友可参考一下。

变量范围
变量的范围即它定义的上下文背景(也就是它的生效范围)。大部分的 PHP 变量只有一个单独的范围。这个单独的范围跨度同样包含了 include 和 require 引入的文件。例如:

 代码如下 复制代码
$a = 1;
include 'b.inc';
?>

这里变量 $a 将会在包含文件 b.inc 中生效。但是,在用户自定义函数中,一个局部函数范围将被引入。任何用于函数内部的变量按缺省情况将被限制在局部函数范围内。例如:

 代码如下 复制代码

$a = 1; /* global scope */

function Test()
{
    echo $a; /* reference to local scope variable */
}

Test();
?>

这个脚本不会有任何输出,因为 echo 语句引用了一个局部版本的变量 $a,而且在这个范围内,它并没有被赋值。你可能注意到 PHP 的全局变量和 C 语言有一点点不同,在 C 语言中,全局变量在函数中自动生效,除非被局部变量覆盖。这可能引起一些问题,有些人可能不小心就改变了一个全局变量。PHP 中全局变量在函数中使用时必须申明为global。


在PHP 中引用的意思是:不同的名字访问同一个变量内容.
与C语言中的指针是有差别的.C语言中的指针里面存储的是变量的内容在内存中存放的地址
变量的引用

 代码如下 复制代码
$a="ABC";
$b =&$a;
echo $a;echo "rn";//这里输出:ABC
echo $b;echo "rn";//这里输出:ABC
$b="EFG";
echo $a;echo "rn";//这里$a的值变为EFG 所以输出EFG
echo $b;echo "rn";//这里输出EFG
?>

函数的传址调用
传址调用我就不多说了 下面直接给出代码

 代码如下 复制代码
function test(&$a)
{
$a=$a+100;
}
$b=1;
echo $b;//输出1
echo "
";
test($b);   //这里$b传递给函数的其实是$b的变量内容所处的内存地址,通过在函数里改变$a的值 就可以改变$b的值了
echo "
";
echo $b;//输出101
?>

要注意的是,在这里test(1);的话就会出错,原因自己去想
函数的引用返回
先看代码

 代码如下 复制代码

function &test()
{
static $b=0;//申明一个静态变量
$b=$b+1;
echo $b;
return $b;
}
$a=test();//这条语句会输出 $b的值 为1
echo "
";
$a=5;
$a=test();//这条语句会输出 $b的值 为2
echo "
";
$a=&test();//这条语句会输出 $b的值 为3
echo "
";
$a=5;
$a=test();//这条语句会输出 $b的值 为6
?>

下面解释下: 
通过这种方式$a=test();得到的其实不是函数的引用返回,这跟普通的函数调用没有区别 至于原因:这是php的规定。
php规定通过$a=&test(); 方式得到的才是函数的引用返回。
至于什么是引用返回呢(php手册上说:引用返回用在当想用函数找到引用应该被绑定在哪一个变量上面时。) 这句狗屁话 害我半天没看懂
用上面的例子来解释就是
$a=test()方式调用函数,只是将函数的值赋给$a而已, 而$a做任何改变 都不会影响到函数中的$b
而通过$a=&test()方式调用函数呢, 他的作用是 将return $b中的 $b变量的内存地址与$a变量的内存地址 指向了同一个地方
即产生了相当于这样的效果($a=&b;) 所以改变$a的值 也同时改变了$b的值 所以在执行了
$a=&test();
$a=5;
以后,$b的值变为了5
这里是为了让大家理解函数的引用返回才使用静态变量的,其实函数的引用返回多用在对象中
对象的引用

 代码如下 复制代码

class a{
public $abc="ABC";
}
$b=new a;
$c=$b;
echo $b->abc;//这里输出ABC
echo $c->abc;//这里输出ABC
$b->abc="DEF";
echo $c->abc;//这里输出DEF
?>

以上代码是在PHP5中的运行效果
在PHP5中 对象的复制 是通过引用来实现的。上列中$b=new a; $c=$b; 其实等效于$b=new a; $c=&$b;
PHP5中默认就是通过引用来调用对象, 但有时你可能想建立一个对象的副本,并希望原来的对象的改变不影响到副本 . 为了这样的目的,PHP定义了一个特殊的方法,称为__clone.
比如下面的例子

 代码如下 复制代码

class a{
public $abc="ABC";
}
$b=new a;
$c=$b;
$d = clone$b;
echo $b->abc;//这里输出ABC
echo $c->abc;//这里输出ABC
$b->abc="DEF";
echo $c->abc;//这里输出DEF
echo $b->abc;//这里输出DEF
$d->abc="111";
echo $d->abc;//这里输出111
echo $b->abc;//这里输出DEF,说明clone后的副本$d对象的改变并没有影响$b对象
?>

引用的作用
如果程序比较大,引用同一个对象的变量比较多,并且希望用完该对象后手工清除它,个人建议用 "&" 方式,然后用$var=null的方式清除. 其它时候还是用php5的默认方式吧. 另外, php5中对
于大数组的传递,建议用 "&" 方式, 毕竟节省内存空间使用。

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

 代码如下 复制代码
$a = 1;
$b = &$a;
unset ($a);
var_dump($a);//这里输出null
var_dump($b);//这里输出int 1
?>

不会 unset $b,只是 $a。

global 引用
当用 global $var 声明一个变量时实际上建立了一个到全局变量的引用。也就是说和这样做是相同的:
$var =& $GLOBALS["var"];
?>
这意味着,例如,unset $var 不会 unset 全局变量。
$this
在一个对象的方法中,$this 永远是调用它的对象的引用。

//下面再来个小插曲
php中对于地址的指向(类似指针)功能不是由用户自己来实现的,是由Zend核心实现的,php中引用采用的是“写时拷贝”的原理,就是除非发生写操作,指向同一个地址的变量或者对象是
不会被拷贝的。
通俗的讲
1:如果有下面的代码
$a="ABC";
$b=$a;
其实此时 $a与$b都是指向同一内存地址 而并不是$a与$b占用不同的内存
2:如果在上面的代码基础上再加上如下代码
$a="ABC";
$b=$a;
$a="EFG";
由于$a与$b所指向的内存的数据要重新写一次了,此时Zend核心会自动判断 自动为$b生产一个$a的数据拷贝,重新申请一块内存进行存储

php 学习之变量传递!

1 用url传递变量

实例

 代码如下 复制代码



my favorite moviesite


echo "my favorite movie site is :";
echo $_GET['favmovie'];
echo "";
$movierate= 5 ;
echo "my favorite movie rating for this movie is ";
echo  $movierate;
?>

将这个文件保存为movie1.php.

用$_GET['favmovie']来接收url传递的变量!

写入另外一个文件保存为

moviesite.php

 代码如下 复制代码


 


  find my favorite movie
 
 
   //$myfavmovie=urlencode("life of brian");
 echo "";
 echo "click here to see more information about my favorite movie!";
 echo "
";
 ?>
 

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn