php 5.3新增的闭包语法介绍function() use() {}

版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/lgg201/article/details/6127564

文中所描述的观点或代码有不正确的地方, 请指正, 以免误导他人, 谢谢

 

 

php 5.3新增闭包语法介绍function() use()

01-10

本文博客地址: [url=http://blog.csdn.net/lgg201/archive/2011/01/10/6127564.aspx]http://blog.csdn.net/lgg201/archive/2011/01/10/6127564.aspx[/url]rnrn有修改建议或发现错误, 请指正, 避免误导他人, 谢谢...rnrn[code=PHP]rn\nrn//这里是直接定义一个匿名函数进行传递, 在以往的版本中, 这是不可用的.rn//现在, 这种语法非常舒服, 和javascript语法基本一致, 之所以说基本呢, 需要继续向下看rn//结论: 一个舒服的语法必然会受欢迎的.rncallback(function() rn print "This is a anonymous function. \n";rn);rnrn//输出: This is a closure use string value, msg is: Hello, everyone. \nrn//这里首先定义了一个闭包, 这次户口本上有名字了...rn//use, 一个新鲜的家伙...rn//众所周知, 闭包: 内部函数使用了外部函数中定义的变量.rn//在PHP新开放的闭包语法中, 我们就是用use来使用闭包外部定义的变量的.rn//这里我们使用了外部变量$msg, 定义完之后, 又对其值进行了改变, 闭包被执行后输出的是原始值rn//结论: 以传值方式传递的基础类型参数, 闭包use的值在闭包创建是就确定了.rn$msg = "Hello, everyone";rn$callback = function () use ($msg) rn print "This is a closure use string value, msg is: $msg. \n";rn;rn$msg = "Hello, everybody";rncallback($callback);rnrn//输出: This is a closure use string value lazy bind, msg is: Hello, everybody. \nrn//换一种引用方式, 我们使用引用的方式来usern//可以发现这次输出是闭包定义后的值...rn//这个其实不难理解, 我们以引用方式use, 那闭包use的是$msg这个变量的地址rn//当后面对$msg这个地址上的值进行了改变之后, 闭包内再输出这个地址的值时, 自然改变了.rn$msg = "Hello, everyone";rn$callback = function () use (&$msg) rn print "This is a closure use string value lazy bind, msg is: $msg. \n";rn;rn$msg = "Hello, everybody";rncallback($callback);rnrn//输出: This is a closure use object, msg is: Hello, everyone. \nrn//闭包中输出的是之前被拷贝的值为Hello, everyone的对象, 后面是对$obj这个名字的一个重新赋值.rn//可以这样考虑rn//1. obj是对象Hello, everyone的名字rn//2. 对象Hello, everyone被闭包use, 闭包产生了一个对Hello, everyone对象的引用rn//3. obj被修改为Hello, everybody这个对象的名字rn//4. 注意, 是名字obj代表的实体变了, 而不是Hello, everyone对象, 那自然闭包的输出还是前面的Hello, everyonern$obj = (object) "Hello, everyone";rn$callback = function () use ($obj) rn print "This is a closure use object, msg is: $obj->scalar. \n";rn;rn$obj = (object) "Hello, everybody";rncallback($callback);rnrn//输出: This is a closure use object, msg is: Hello, everybody. \nrn//还是按照上面的步骤, 按部就班的来吧:rn//1. obj名字指向Hello, everyone对象rn//2. 闭包产生一个引用指向Hello, everyone对象rn//3. 修改obj名字指向的对象(即Hello, everyone对象)的scalar值rn//4. 执行闭包, 输出的自然是Hello, everybody, 因为其实只有一个真正的对象rn$obj = (object) "Hello, everyone";rn$callback = function () use ($obj) rn print "This is a closure use object, msg is: $obj->scalar. \n";rn;rn$obj->scalar = "Hello, everybody";rncallback($callback);rnrn//输出: This is a closure use object lazy bind, msg is: Hello, everybody. \nrn//闭包引用的是什么呢? &$obj, 闭包产生的引用指向$obj这个名字所指向的地址.rn//因此, 无论obj怎么变化, 都是逃不脱的....rn//所以, 输出的就是改变后的值rn$obj = (object) "Hello, everyone";rn$callback = function () use (&$obj) rn print "This is a closure use object lazy bind, msg is: $obj->scalar. \n";rn;rn$obj = (object) "Hello, everybody";rncallback($callback);rnrn/**rn * 一个利用闭包的计数器产生器rn * 这里其实借鉴的是python中介绍闭包时的例子...rn * 我们可以这样考虑:rn * 1. counter函数每次调用, 创建一个局部变量$counter, 初始化为1.rn * 2. 然后创建一个闭包, 闭包产生了对局部变量$counter的引用.rn * 3. 函数counter返回创建的闭包, 并销毁局部变量, 但此时有闭包对$counter的引用, rn * 它并不会被回收, 因此, 我们可以这样理解, 被函数counter返回的闭包, 携带了一个游离态的rn * 变量.rn * 4. 由于每次调用counter都会创建独立的$counter和闭包, 因此返回的闭包相互之间是独立的.rn * 5. 执行被返回的闭包, 对其携带的游离态变量自增并返回, 得到的就是一个计数器.rn * 结论: 此函数可以用来生成相互独立的计数器.rn */rnfunction counter() rn $counter = 1;rn return function() use(&$counter) return $counter ++;;rnrn$counter1 = counter();rn$counter2 = counter();rnecho "counter1: " . $counter1() . " \n";rnecho "counter1: " . $counter1() . " \n";rnecho "counter1: " . $counter1() . " \n";rnecho "counter1: " . $counter1() . " \n";rnecho "counter2: " . $counter2() . " \n";rnecho "counter2: " . $counter2() . " \n";rnecho "counter2: " . $counter2() . " \n";rnecho "counter2: " . $counter2() . " \n";rn?>rn[/code]

没有更多推荐了,返回首页

私密
私密原因:
请选择设置私密原因
  • 广告
  • 抄袭
  • 版权
  • 政治
  • 色情
  • 无意义
  • 其他
其他原因:
120
出错啦
系统繁忙,请稍后再试