具体代码
<?php /** * 设置超时时间,变成不限制 * */ set_time_limit(0); /** * 本函数模拟非常耗时的任务,执行完毕需要5秒的时间 */ function writeFile() { $path = 'D:/phpstudy_pro/WWW/kaka.txt'; file_put_contents($path,'程序运行开始' . PHP_EOL,FILE_APPEND); for($i =0;$i < 5;$i++) { file_put_contents($path,time() . PHP_EOL,FILE_APPEND); sleep(1); } file_put_contents($path,'程序运行结束' . PHP_EOL,FILE_APPEND); } /** * 输出文字标记,任务开始 */ echo('任务开始'); /** * 后台执行非常耗时的任务 */ register_shutdown_function(writeFile); /** * 立即发送请求 */ fastcgi_finish_request();
以上测试全部使用linux系统进行测试哈,否则你看不到直观的效果。
经过上面的演示,响应非常快,浏览器响应结束后,后台程序依然进行执行每秒执行一个时间戳。
以上就是对fastcgi_finish_request方法的简单介绍,如果你也感兴趣可以进行简单的尝试一下,有助于更好的去理解其中的小秘密。
八、trait特性讲解
应该在俩年前咔咔就对这个特性进行过一次解析,trait就是常说的超类。
这个特性是在PHP5.4才加入的,这个特性不是经常使用的接口更不是类。
这个特性是为了解决PHP的一大弱点只能单继承的缺点,但是也不能叫多继承,严谨一点的就是类似多继承的功能而已。
接下来给大家演示一个案例。
创建test文件一,并且返回对应类名。
创建test1文件,并且返回对应类名
创建控制器文件用来输出信息。
然后在控制器中引入对应的超类文件,这里需要注意的是圈住的第一个框,这个框就是直接引入超类test文件。
然后可以直接进行访问,看会返回什么。
通过上图访问结果结果可以看得到返回的是Test超类文件的方法,但是此控制器同样也基础了Controller控制器,这也就是在文章一开头就说的超类就是实现了一种多继承的功能而已。
但是这里会存在一个问题,请看下图报错信息。
上图的报错信息是因为在控制器中使用了俩个超类导致的,也就是下图的使用方式。
那么如何解决这种报错信息呢!接下来跟这咔咔的节奏一起来。
解决报错信息
在解决之前问题之前得先清楚这个问题是由于什么引起的。
出现这个错误的原因是引用的两个trait里面有同名的hello函数,出现了冲突。
但是在日常开发中这种情况都是可以避免的,因为手动改方法名还是很方便的,但是这里咔咔教大家如何解决这种问题。
一是用其中一个trait里的hello方法覆盖另外一个trait的同名方法,因为两个方法内容是一致的,所以我这里直接选择insteadof覆盖;
二是给他们用as起别名,这样就不会有冲突了。as关键词还有另外一个用途,那就是修改方法的访问控制。
经过上图的改动之后,再一次的进行访问,看一下返回结果。
那么这个时候就会有伙伴有疑问了,就是案例打印结果一直是Test类的方法,Test1类的方法一直没有进行打印。
那是如何进行访问的呢!来接着看一下。
从上图可以看到将访问方法改为了别名控制访问,接着来看一下访问结果。
从上图中可以可以看到返回结果就是超类Test1类的返回结果。
那么关于as这个的使用就需要大家在去搜索一下使用方式,有时候注意一下细节就可以学到很多知识点。
总结
直到这里关于控制器的源码解析就到这了,咔咔通过源码给大家分析控制器的如如何进行实例化的。
也再一次的进行了对ArrayAccess和魔术方法的调用关系,一定要有自己的思考去想问题。
在就是对访问控制器后是如何进行响应数据的,等等。
也在源码中学到了关于fastcgi_finish_request方法巧用,但是在使用这个函数一定要注意关于咔咔提到的俩个注意点。
最后就是对超类的一个简单案例描述。