PHP语言其实并不支持多线程,网上有很多关于PHP多线程的方法,其实是PHP利用了其LINUX和APACHE的多线程能力而已。
另外, 既然是模拟的, 就不是真正的多线程. 其实只是多进程. 进程和线程是两个不同的概念. 好了, 以下方法都是从网上找来的.
1. 利用LINUX操作系统
<?phpfor ($i=0;$i<10;$i++) { echo $i; sleep(5);}?>
上面存成test.php, 然后写一段SHELL代码
#!/bin/bashfor i in 1 2 3 4 5 6 7 8 9 10do php -q test.php &done
2. 利用fork子进程(其实同样是利用LINUX操作系统)
<?phpdeclare(ticks=1);$bWaitFlag = FALSE; /// 是否等待进程结束$intNum = 10; /// 进程总数$pids = array(); /// 进程PID数组echo ("Startn");for($i = 0; $i < $intNum; $i++) { $pids[$i] = pcntl_fork();/// 产生子进程,而且从当前行之下开试运行代码,而且不继承父进程的数据信息 if(!$pids[$i]) { // 子进程进程代码段_Startwww.it165.net $str=""; sleep(5+$i); for ($j=0;$j<$i;$j++) {$str.="*";} echo "$i -> " . time() . " $str n"; exit(); // 子进程进程代码段_End }}if ($bWaitFlag){ for($i = 0; $i < $intNum; $i++) { pcntl_waitpid($pids[$i], $status, WUNTRACED); echo "wait $i -> " . time() . "n"; }}echo ("Endn");?>
3. 利用WEB SERVER, PHP不支持多线程, APACHE可是支持的, 呵呵.
假设我们现在运行的是a.php这个文档. 但是我在程式中又请求WEB服务器运行另一个b.php
那么这两个文档将是同时执行的.
<?phpfunction runThread(){ $fp = fsockopen('localhost', 80, $errno, $errmsg); fputs($fp, "GET /a.php?act=brnrn"); fclose($fp);}function a(){ $fp = fopen('result_a.log', 'w'); fputs($fp, 'Set in ' . Date('h:i:s', time()) . (double)microtime() . "rn"); fclose($fp);}function b(){ $fp = fopen('result_b.log', 'w'); fputs($fp, 'Set in ' . Date('h:i:s', time()) . (double)microtime() . "rn"); fclose($fp);}if(!isset($_GET['act'])) $_GET['act'] = 'a';if($_GET['act'] == 'a'){ runThread(); a();}else if($_GET['act'] == 'b') b();?>
当然啦,也可以把需要多线程处理的部分交给JAVA去处理, 然后在PHP里调用, 哈哈.
<?phpsystem('java multiThread.java');?>
不知道还有没有更多别的方法. 不过, 无论如何, PHP不支持多线程这一点实在是让我耿耿于怀.
PHP编程郑重声明:本文版权归原作者所有,转载文章仅为传播更多信息之目的,如作者信息标记有误,请第一时间联系我们修改或删除,多谢。
新闻热点
疑难解答