首页 后端开发 php教程 php 53新增的闭包语法介绍function use {} jquery function objective function likelihood function

php 53新增的闭包语法介绍function use {} jquery function objective function likelihood function

Jul 29, 2016 am 08:53 AM
function

转载原帖址:http://blog.csdn.net/lgg201/article/details/6127564

<code><span><span><span><?php </span><span><span>function</span><span>callback</span><span>(<span>$callback</span>)</span> {</span><span>$callback</span>();
}
<span>//输出: This is a anonymous function.<br>/n</span><span>//这里是直接定义一个匿名函数进行传递, 在以往的版本中, 这是不可用的.</span><span>//现在, 这种语法非常舒服, 和<a href="http://lib.csdn.net/base/18" title="JavaScript知识库" target="_blank">javascript</a>语法基本一致, 之所以说基本呢, 需要继续向下看</span><span>//结论: 一个舒服的语法必然会受欢迎的.</span>
callback(<span><span>function</span><span>()</span> {</span><span>print</span><span>"This is a anonymous function.<br>/n"</span>;
});
<span>//输出: This is a closure use string value, msg is: Hello, everyone.<br>/n</span><span>//这里首先定义了一个闭包, 这次户口本上有名字了...</span><span>//use, 一个新鲜的家伙...</span><span>//众所周知, 闭包: 内部函数使用了外部函数中定义的变量.</span><span>//在PHP新开放的闭包语法中, 我们就是用use来使用闭包外部定义的变量的.</span><span>//这里我们使用了外部变量$msg, 定义完之后, 又对其值进行了改变, 闭包被执行后输出的是原始值</span><span>//结论: 以传值方式传递的基础类型参数, 闭包use的值在闭包创建是就确定了.</span><span>$msg</span> = <span>"Hello, everyone"</span>;
<span>$callback</span> = <span><span>function</span><span>()</span><span>use</span><span>(<span>$msg</span>)</span> {</span><span>print</span><span>"This is a closure use string value, msg is: $msg. <br>/n"</span>;
};
<span>$msg</span> = <span>"Hello, everybody"</span>;
callback(<span>$callback</span>);
<span>//输出: This is a closure use string value lazy bind, msg is: Hello, everybody.<br>/n</span><span>//换一种引用方式, 我们使用引用的方式来use</span><span>//可以发现这次输出是闭包定义后的值...</span><span>//这个其实不难理解, 我们以引用方式use, 那闭包use的是$msg这个变量的地址</span><span>//当后面对$msg这个地址上的值进行了改变之后, 闭包内再输出这个地址的值时, 自然改变了.</span><span>$msg</span> = <span>"Hello, everyone"</span>;
<span>$callback</span> = <span><span>function</span><span>()</span><span>use</span><span>(&<span>$msg</span>)</span> {</span><span>print</span><span>"This is a closure use string value lazy bind, msg is: $msg. <br>/n"</span>;
};
<span>$msg</span> = <span>"Hello, everybody"</span>;
callback(<span>$callback</span>);
<span>//输出: This is a closure use object, msg is: Hello, everyone.<br>/n</span><span>//闭包中输出的是之前被拷贝的值为Hello, everyone的对象, 后面是对$obj这个名字的一个重新赋值.</span><span>//可以这样考虑</span><span>//1. obj是对象Hello, everyone的名字</span><span>//2. 对象Hello, everyone被闭包use, 闭包产生了一个对Hello, everyone对象的引用</span><span>//3. obj被修改为Hello, everybody这个对象的名字</span><span>//4. 注意, 是名字obj代表的实体变了, 而不是Hello, everyone对象, 那自然闭包的输出还是前面的Hello, everyone</span><span>$obj</span> = (object) <span>"Hello, everyone"</span>;
<span>$callback</span> = <span><span>function</span><span>()</span><span>use</span><span>(<span>$obj</span>)</span> {</span><span>print</span><span>"This is a closure use object, msg is: {$obj->scalar}. <br>/n"</span>;
};
<span>$obj</span> = (object) <span>"Hello, everybody"</span>;
callback(<span>$callback</span>);
<span>//输出: This is a closure use object, msg is: Hello, everybody.<br>/n</span><span>//还是按照上面的步骤, 按部就班的来吧:</span><span>//1. obj名字指向Hello, everyone对象</span><span>//2. 闭包产生一个引用指向Hello, everyone对象</span><span>//3. 修改obj名字指向的对象(即Hello, everyone对象)的scalar值</span><span>//4. 执行闭包, 输出的自然是Hello, everybody, 因为其实只有一个真正的对象</span><span>$obj</span> = (object) <span>"Hello, everyone"</span>;
<span>$callback</span> = <span><span>function</span><span>()</span><span>use</span><span>(<span>$obj</span>)</span> {</span><span>print</span><span>"This is a closure use object, msg is: {$obj->scalar}. <br>/n"</span>;
};
<span>$obj</span>->scalar = <span>"Hello, everybody"</span>;
callback(<span>$callback</span>);
<span>//输出: This is a closure use object lazy bind, msg is: Hello, everybody.<br>/n</span><span>//闭包引用的是什么呢? &$obj, 闭包产生的引用指向$obj这个名字所指向的地址.</span><span>//因此, 无论obj怎么变化, 都是逃不脱的....</span><span>//所以, 输出的就是改变后的值</span><span>$obj</span> = (object) <span>"Hello, everyone"</span>;
<span>$callback</span> = <span><span>function</span><span>()</span><span>use</span><span>(&<span>$obj</span>)</span> {</span><span>print</span><span>"This is a closure use object lazy bind, msg is: {$obj->scalar}. <br>/n"</span>;
};
<span>$obj</span> = (object) <span>"Hello, everybody"</span>;
callback(<span>$callback</span>);
<span>/**
 * 一个利用闭包的计数器产生器
 * 这里其实借鉴的是<a href="http://lib.csdn.net/base/11" title="Python知识库" target="_blank">python</a>中介绍闭包时的例子...
 * 我们可以这样考虑:
 *      1. counter函数每次调用, 创建一个局部变量$counter, 初始化为1.
 *      2. 然后创建一个闭包, 闭包产生了对局部变量$counter的引用.
 *      3. 函数counter返回创建的闭包, 并销毁局部变量, 但此时有闭包对$counter的引用, 
 *          它并不会被回收, 因此, 我们可以这样理解, 被函数counter返回的闭包, 携带了一个游离态的
 *          变量.
 *      4. 由于每次调用counter都会创建独立的$counter和闭包, 因此返回的闭包相互之间是独立的.
 *      5. 执行被返回的闭包, 对其携带的游离态变量自增并返回, 得到的就是一个计数器.
 * 结论: 此函数可以用来生成相互独立的计数器.
 */</span><span><span>function</span><span>counter</span><span>()</span> {</span><span>$counter</span> = <span>1</span>;
    <span>return</span><span><span>function</span><span>()</span><span>use</span><span>(&<span>$counter</span>)</span> {</span><span>return</span><span>$counter</span> ++;};
}
<span>$counter1</span> = counter();
<span>$counter2</span> = counter();
<span>echo</span><span>"counter1: "</span> . <span>$counter1</span>() . <span>"<br>/n"</span>;
<span>echo</span><span>"counter1: "</span> . <span>$counter1</span>() . <span>"<br>/n"</span>;
<span>echo</span><span>"counter1: "</span> . <span>$counter1</span>() . <span>"<br>/n"</span>;
<span>echo</span><span>"counter1: "</span> . <span>$counter1</span>() . <span>"<br>/n"</span>;
<span>echo</span><span>"counter2: "</span> . <span>$counter2</span>() . <span>"<br>/n"</span>;
<span>echo</span><span>"counter2: "</span> . <span>$counter2</span>() . <span>"<br>/n"</span>;
<span>echo</span><span>"counter2: "</span> . <span>$counter2</span>() . <span>"<br>/n"</span>;
<span>echo</span><span>"counter2: "</span> . <span>$counter2</span>() . <span>"<br>/n"</span>;
<span>?></span></span></span></span></code>
登录后复制
').addClass('pre-numbering').hide(); $(this).addClass('has-numbering').parent().append($numbering); for (i = 1; i ').text(i)); }; $numbering.fadeIn(1700); }); });

以上就介绍了php 53新增的闭包语法介绍function use {},包括了function方面的内容,希望对PHP教程有兴趣的朋友有所帮助。

本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover

AI Clothes Remover

用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool

Undress AI Tool

免费脱衣服图片

Clothoff.io

Clothoff.io

AI脱衣机

Video Face Swap

Video Face Swap

使用我们完全免费的人工智能换脸工具轻松在任何视频中换脸!

热工具

记事本++7.3.1

记事本++7.3.1

好用且免费的代码编辑器

SublimeText3汉化版

SublimeText3汉化版

中文版,非常好用

禅工作室 13.0.1

禅工作室 13.0.1

功能强大的PHP集成开发环境

Dreamweaver CS6

Dreamweaver CS6

视觉化网页开发工具

SublimeText3 Mac版

SublimeText3 Mac版

神级代码编辑软件(SublimeText3)

function是什么意思 function是什么意思 Aug 04, 2023 am 10:33 AM

function是函数的意思,是一段具有特定功能的可重复使用的代码块,是程序的基本组成单元之一,可以接受输入参数,执行特定的操作,并返回结果,其目的是封装一段可重复使用的代码,提高代码的可重用性和可维护性。

'enumerate()'函数在Python中的用途是什么? 'enumerate()'函数在Python中的用途是什么? Sep 01, 2023 am 11:29 AM

在本文中,我们将了解enumerate()函数以及Python中“enumerate()”函数的用途。什么是enumerate()函数?Python的enumerate()函数接受数据集合作为参数并返回一个枚举对象。枚举对象以键值对的形式返回。key是每个item对应的索引,value是items。语法enumerate(iterable,start)参数iterable-传入的数据集合可以作为枚举对象返回,称为iterablestart-顾名思义,枚举对象的起始索引由start定义。如果我们忽

MySQL.proc表的作用和功能详解 MySQL.proc表的作用和功能详解 Mar 16, 2024 am 09:03 AM

MySQL.proc表的作用和功能详解MySQL是一种流行的关系型数据库管理系统,开发者在使用MySQL时常常会涉及到存储过程(StoredProcedure)的创建和管理。而MySQL.proc表则是一个非常重要的系统表,它存储了数据库中所有的存储过程的相关信息,包括存储过程的名称、定义、参数等。在本文中,我们将详细解释MySQL.proc表的作用和功能

Vue.use函数的用法和作用 Vue.use函数的用法和作用 Jul 24, 2023 pm 06:09 PM

Vue.use函数的用法和作用Vue是一款流行的前端框架,它提供了许多有用的功能和功能。其中之一就是Vue.use函数,它可以让我们在Vue应用中使用插件。本文将介绍Vue.use函数的用法和作用,并且提供一些代码示例。Vue.use函数的基本用法非常简单,只需在Vue实例化之前调用它,并传入要使用的插件作为参数。下面是一个简单的示例://引入并使用插件

在PHP中的clearstatcache()函数 在PHP中的clearstatcache()函数 Sep 07, 2023 am 09:33 AM

clearstatcache()函数用于清除文件状态缓存。PHP缓存以下函数返回的信息−stat()lstat()file_exists()is_writable()is_readable()is_executable()is_file()is_dir()filegroup()fileowner()filesize()filetype()fileperms()这样做是为了提供更好的性能。语法voidclearstatecache()参数NA返回值clearstatcache(

在PHP中的file_exists()函数 在PHP中的file_exists()函数 Sep 14, 2023 am 08:29 AM

file_exists方法检查文件或目录是否存在。它接受要检查的文件或目录的路径作为参数。以下是它的用途-当您需要在处理之前知道文件是否存在时,它非常有用。这样,在创建新文件时使用此函数即可知道该文件是否已存在。语法file_exists($file_path)参数file_path-设置要检查是否存在的文件或目录的路径。必需。返回file_exists()方法返回。如果文件或目录存在,则返回TrueFalse,如果文件或目录不存在示例让我们看一个检查“candidate.txt”文件和即使文件

js函数function用法是什么 js函数function用法是什么 Oct 07, 2023 am 11:25 AM

js函数function用法有:1、声明函数;2、调用函数;3、函数参数;4、函数返回值;5、匿名函数;6、函数作为参数;7、函数作用域;8、递归函数。

如何在PHP中使用SOA函数 如何在PHP中使用SOA函数 May 18, 2023 pm 01:10 PM

随着互联网的发展,SOA(面向服务的架构)已经成为了当今企业级系统中的一种重要的技术架构。SOA架构中的服务可以被重复使用、重组和扩展,同时还能够简化系统开发和维护的过程。PHP作为一种被广泛使用的Web编程语言,也提供了一些用于实现SOA的函数库。接下来,我们将详细介绍如何在PHP中使用SOA函数。一、SOA的基本概念SOA是一种分布式系统开发的思想和架构

See all articles