php Pthread 多线程 (一) 基本介绍
我们可以通过安装Pthread扩展来让PHP支持多线程。
<?php//实现多线程必须继承Thread类
class test extends Thread {public function __construct($arg){$this->arg = $arg;}//当调用start方法时,该对象的run方法中的代码将在独立线程中异步执行。public function run(){if($this->arg){printf("Hello %s\n", $this->arg);}}
}
$thread = new test("World");if($thread->start()) {//join方法的作用是让当前主线程等待该线程执行完毕//确认被join的线程执行结束,和线程执行顺序没关系。//也就是当主线程需要子线程的处理结果,主线程需要等待子线程执行完毕//拿到子线程的结果,然后处理后续代码。$thread->join();
}
?>
我们把上述代码修改一下,看看效果
<?phpclass test extends Thread {public function __construct($arg){$this->arg = $arg;}public function run(){if($this->arg){sleep(3);printf("Hello %s\n", $this->arg);}}
}
$thread = new test("World");$thread->start();echo "main thread\r\n";
?>
我们直接调用start方法,而没有调用join。主线程不会等待,而是在输出main thread。子线程等待3秒才输出Hello World。
<?php
class test extends Thread {private $name = '';private $res = null;public function __construct($name, $res){$this->name = $name;$this->res = $res;}public function run(){while(!feof($this->res)) {if(flock($this->res, LOCK_EX)) {$data = fgets($this->res);$data = trim($data);echo "Thread {$this->name} Read {$data} \r\n";sleep(1);flock($this->res, LOCK_UN);}}}
}$fp = fopen('./test.log', 'rb');$threads[] = new test('a', $fp);
$threads[] = new test('b', $fp);foreach($threads as $thread) {$thread->start();
}foreach($threads as $thread) {$thread->join();
}
?>
我们通过创建两个线程a和b来读取文件test.log中的内容。(*注意,在并发读写文件时,一定要给文件加锁。这里给文件加上独占锁,如果加共享锁会出现读取相同数据。)
111111
222222
333333
444444
555555
666666
执行结果如下:
<?php
class Total extends Thread {public $name = '';private $total = 0;private $startNum = 0;private $endNum = 0;public function __construct($name, $startNum, $endNum){$this->name = $name;$this->startNum = $startNum;$this->endNum = $endNum;}public function run(){for($ix = $this->startNum; $ix < $this->endNum; ++$ix) {$this->total += $ix;}echo "Thread {$this->name} total: {$this->total} \r\n";}public function getTotal() {return $this->total;}
}$num = 10000000;
$threadNum = 10;
$setp = $num / $threadNum;
$startNum = 0;$startTime = microtime(true);
for($ix = 0; $ix < $threadNum; ++$ix) {$endNum = $startNum + $setp;$thread = new Total($ix, $startNum, $endNum);$thread->start();$startNum = $endNum;$threads[] = $thread;
}$total = 0;
foreach($threads as $thread) {$thread->join();$total += $thread->getTotal();
}$endTime = microtime(true);
$time = $endTime - $startTime;echo "total : {$total} time : {$time} \r\n";
我们通过创建10个线程,分别计算累加和,而后主线程把10个线程计算的结果统一相加得到最后结果。
我们不使用多线程,来计算这累加和,代码如下:
<?php
$total = 0;$startTime = microtime(true);for($ix = 0; $ix < 10000000; ++$ix) {$total += $ix;
}$endTime = microtime(true);
$time = $endTime - $startTime;echo "total : {$total} time : {$time} \r\n";
我们可以看到使用多线程和不使用,得到的结果是一样的,但是处理时间,多线程就慢很多。(*主要是线程的创建也是需要资源的,而且线程之间的相互切换也需要时间,这里的例子主要说明如何把一个问题分配给多个子线程去处理,然后主线程拿到子线程的结果并处理得到我们需要的结果。)
转载于:https://www.cnblogs.com/jkko123/p/6351604.html
php Pthread 多线程 (一) 基本介绍相关推荐
- pthread多线程编程的学习小结
pthread多线程编程的学习小结 pthread 同步3种方法: 1 mutex 2 条件变量 3 读写锁:支持多个线程同时读,或者一个线程写 程序员必上的开发者服务平台 -- DevStore p ...
- clone的fork与pthread_create创建线程有何不同pthread多线程编程的学习小结(转)
进程是一个指令执行流及其执行环境,其执行环境是一个系统资源的集合,这些资源在Linux中被抽 象成各种数据对象:进程控制块.虚存空间.文件系统,文件I/O.信号处理函数.所以创建一个进程的 过程就是这 ...
- clone的fork与pthread_create创建线程有何不同pthread多线程编程的学习小结
进程是一个指令执行流及其执行环境,其执行环境是一个系统资源的集合,这些资源在Linux中被抽 象成各种数据对象:进程控制块.虚存空间.文件系统,文件I/O.信号处理函数.所以创建一个进程的 过程就是这 ...
- Pthread多线程编程之查看Pthread版本的方法
Pthread多线程编程之查看Pthread版本的方法: getconf GNU_LIBPTHREAD_VERSION [root@localhost Workspace]# getconf GNU_ ...
- Qt-Creator编译pthread多线程程序的方法
因为phread属于第三方库,需要在Qt项目的pro文件中添加一行: LIBS += -pthread 至此,Qt-Creator顺利编译pthread多线程程序,大功告成...
- pthread多线程库下载
pthread多线程库下载地址:ftp://sourceware.org/pub/pthreads-win32 用Edge浏览器貌似进不去
- Android NDK JNI C++ 13 pthread多线程
这一篇将初步介绍NDK开发中多线程方面相关操作,具体步骤如下: 多线程采用 POSIX 的pthread方式实现. <1> : 新建一个Android工程 androidpthreadjn ...
- pthread线程库使用介绍
多线程的开发和应用在平时的项目中使用非常频繁.Linux C++中,一般使用pthread库操作线程相关业务,不少公司一般都会基于该线程库的基本接口进行封装,使用起来更加方便易用.本文对该线程库的常用 ...
- Linux 信号可靠性,同步,异步,多线程信号等介绍
鉴于网上超多关于Linux信号处理相关的文章,本篇关于基本的信号知识不再普及,只提出一些平时不常关注或者关注不到的一些方面: 1. 信号可靠性:此可靠指的是信号是否会排队,并不是指信号会丢失(其实在也 ...
最新文章
- JVM(3)——Java GC分析
- 打造“新基建”核心支柱 数据中心产业期待提速提质
- 网络语言对作文教学的冲击
- spring学习(12):使用junit4进行单元测试
- 同一个容器实例可以同时运行在多个宿主机_从零开始学K8s: 3.什么是容器
- 我厨蔬菜生鲜商城小程序源码
- HTML --- 简单的标签
- copy 自定义对象
- Modernizr 浏览器兼容功能检测
- 一级计算机第65套题,全国计算机一级考试题库(附答案).pdf
- plc编程和python的联系_Python与三菱PLC通信
- python图像纹理提取_图像处理7 LBP纹理特征提取
- y2第一章 初始mybatis的上机3_MyBatis第一章
- 恒玉佳壬二酸使用方法,15壬二酸能帮助祛痘吗
- IDEA设置 代码提示 快捷键
- python学习笔记:插入函数append,extend与insert的使用与区别
- 如何用transition实现翻书动画效果
- 如何让外网访问本地WEB服务器
- C语言编写程序,从键盘输入三角形的三条边,判断它们是否能构成等腰或直角三角形。
- Android第三方QQ登录无限授权
热门文章
- 63. Unique Paths II
- 设置Eclipse中的tab键为4个空格的完整方法
- java实现Kafka生产者示例
- jquery之stop()的用法
- Ext2.2系列(50篇)
- java学习笔记(三)----成员权限,构造函数,this用法
- java 大臣的旅费_PREV-9-蓝桥杯-历届试题-大臣的旅费-java
- 怎么将算法改成程序_多肉烂根怎么办?将土培改成水培,长势好,叶子变得更水灵...
- hdu5056(找相同字母不出现k次的子串个数)
- poj2112 二分最大流+Floyd