PHP之pthread拓展使用以及坑
导读:收集整理的这篇文章主要介绍了PHP之pthread拓展使用以及坑,觉得挺不错的,现在分享给大家,也给大家做个参考。PHP是为WEB开发而生,以前PHP是没有线程的说法,直到pthread的出现,这样php增加了活力;推荐:《PHP教程》一....
收集整理的这篇文章主要介绍了PHP之pthread拓展使用以及坑,觉得挺不错的,现在分享给大家,也给大家做个参考。PHP是为WEB开发而生,以前PHP是没有线程的说法,直到pthread的出现,这样php增加了活力;推荐:《PHP教程》
一. 线程的创建和使用
1. Thread类
基本的创建和使用:
?php//通过继承Thread类来实现自己的线程类MyThreadclass MyThread extends Thread{ //重写构造函数 function __construct(){ } //重写run方法(运行的是子线程需要执行的任务) function run(){ } } //对象的实例化和运行就和java一样$mt = new MyThread(); $mt-> start();
当然,作为线程类,必须还有另外一些用于查询线程状态以及管理线程的方法
?php//获取创建线程的父线程idThread::getCreatorId //获取当前线程idThread::getcurrentThreadId//获取当前线程引用Thread::getCurrentThread //将线程加入检测Thread::join//查看线程是否被检测(是否被join)Thread::isJoined//强行杀死线程Thread::kill
2.Worker类
Worker类的父类是Thread类,因此基本用法和Thread一样。而Worker类相对于Thread类来说,增加了线程复用的功能(以降低创建销毁线程所耗费的资源),通常与Stackable类连用,也就是说worker类既可以当做线程使用,也可以当做任务的容器来使用,如:
?phpclass Task extends Stackable{ function __construct($no){ $this-> no = $no; } function run(){ echo "task{ $this-> no} :run".PHP_EOL; } } class MyWork extends Worker{ function __construct(){ } function run(){ } } $t1= new Task(1); $t2= new Task(2); $t3= new Task(3); $my = new MyWork(); $my-> stack($t1); $my-> stack($t2); $my-> start(); $my-> stack($t3);
最终输出:
task1:runtask2:runtask3:run
当然Worker类还有其他一些方法来用于父线程对其进行管理
//获取还没执行的任务数量Worker::getStacked //判断worker是否关闭Worker::isShutdown//判断worker是否在工作Worker::isWorking//关闭销毁workerWorker::shutdown//将任务压栈Worker::stack//将任务出栈(该api有问题,慎用)Worker::unstack
二. PHP线程遇到的一些问题与注意点
1.线程类的属性不能直接进行哈希表(数组)操作,如:
//这样是无效的$this-> VAR1["hello"] = "world"; //改为$this-> var1 = ["hello"=> "world"];
为什么?因为线程类属性的赋值是通过序列化实现的,其本质是存储了序列化数据,因此不支持PHP常用直接操作哈希表(数组)的操作。
2.线程类的属性不能是“闭包函数”
原因:闭包函数不能序列化;因此,如果想在线程里用“回调函数”的话,那就放弃线程吧;
3.线程对象开辟了php的第二空间
(1)线程在创建之后,无法访问到父线程的变量,诸如$GLOBALS或global等用法都无法操作父线程的全局变量,这应该是考虑到了线程安全的问题;
(2)但是父线程却能够访问子线程对象的内容;
以上就是PHP之pthread拓展使用以及坑的详细内容,更多请关注其它相关文章!
声明:本文内容由网友自发贡献,本站不承担相应法律责任。对本内容有异议或投诉,请联系2913721942#qq.com核实处理,我们将尽快回复您,谢谢合作!
若转载请注明出处: PHP之pthread拓展使用以及坑
本文地址: https://pptw.com/jishu/596061.html