首页 > 开发 > PHP > 正文

PHP多线程编程之管道通信实例分析

2024-05-04 23:32:05
字体:
来源:转载
供稿:网友

这篇文章主要介绍了PHP多线程编程之管道通信,实例分析了管道通信的原理与相关使用技巧,具有一定参考借鉴价值,需要的朋友可以参考下

本文实例讲述了PHP多线程编程之管道通信用法。分享给大家供大家参考。具体分析如下:

一个线程如果是个人英雄主义,那么多线程就是集体主义,你不再是一个独行侠,而是一个指挥家。

管道通信:

1. 管道可以认为是一个队列,不同的线程都可以往里面写东西,也都可以从里面读东西。写就是

在队列末尾添加,读就是在队头删除。

2. 管道一般有大小,默认一般是4K,也就是内容超过4K了,你就只能读,不能往里面写了。

3. 默认情况下,管道写入以后,就会被阻止,直到读取他的程序读取把数据读完。而读取线程也会被阻止,

直到有进程向管道写入数据。当然,你可以改变这样的默认属性,用stream_set_block 函数,设置成非阻断模式。

下面是我分装的一个管道的类(这个类命名有问题,没有统一,没有时间改成统一的了,我一般先写测试代码,最后分装,所以命名上可能不统一):

 

 
  1. <?php 
  2. class Pipe 
  3. public $fifoPath
  4. private $w_pipe
  5. private $r_pipe
  6.  
  7. /** 
  8. * 自动创建一个管道 
  9. * 
  10. * @param string $name 管道名字 
  11. * @param int $mode 管道的权限,默认任何用户组可以读写 
  12. */ 
  13. function __construct($name = 'pipe'$mode = 0666) 
  14. $fifoPath = "/tmp/$name." . posix_getpid(); 
  15. if (!file_exists($fifoPath)) { 
  16. if (!posix_mkfifo($fifoPath$mode)) { 
  17. error("create new pipe ($name) error."); 
  18. return false; 
  19. else { 
  20. error( "pipe ($name) has exit."); 
  21. return false; 
  22. $this->fifoPath = $fifoPath
  23. /////////////////////////////////////////////////// 
  24. // 写管道函数开始 
  25. /////////////////////////////////////////////////// 
  26. function open_write() 
  27. $this->w_pipe = fopen($this->fifoPath, 'w'); 
  28. if ($this->w_pipe == NULL) { 
  29. error("open pipe {$this->fifoPath} for write error."); 
  30. return false; 
  31. return true; 
  32.  
  33. function write($data
  34. return fwrite($this->w_pipe, $data); 
  35.  
  36. function write_all($data
  37. $w_pipe = fopen($this->fifoPath, 'w'); 
  38. fwrite($w_pipe$data); 
  39. fclose($w_pipe); 
  40.  
  41. function close_write() 
  42. return fclose($this->w_pipe); 
  43. ///////////////////////////////////////////////////////// 
  44. /// 读管道相关函数开始 
  45. //////////////////////////////////////////////////////// 
  46. function open_read() 
  47. $this->r_pipe = fopen($this->fifoPath, 'r'); 
  48. if ($this->r_pipe == NULL) { 
  49. error("open pipe {$this->fifoPath} for read error."); 
  50. return false; 
  51. return true; 
  52. function read($byte = 1024) 
  53. return fread($this->r_pipe, $byte); 
  54. function read_all() 
  55. $r_pipe = fopen($this->fifoPath, 'r'); 
  56. $data = ''
  57. while (!feof($r_pipe)) { 
  58. //echo "read one K/n"; 
  59. $data .= fread($r_pipe, 1024); 
  60. fclose($r_pipe); 
  61. return $data
  62. function close_read() 
  63. return fclose($this->r_pipe); 
  64. /** 
  65. * 删除管道 
  66. * 
  67. * @return boolean is success 
  68. */ 
  69. function rm_pipe() 
  70. return unlink($this->fifoPath); 
  71. ?> 
  72. /* 
  73. 有了这个类,就可以实现简单的管道通信了。*/ 

希望本文所述对大家的php程序设计有所帮助。

发表评论 共有条评论
用户名: 密码:
验证码: 匿名发表