当前位置:Gxlcms > PHP教程 > PHP多线程编程之管道通信实例分析_PHP

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

时间:2021-07-01 10:21:17 帮助过:24人阅读

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

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

管道通信:
1. 管道可以认为是一个队列,不同的线程都可以往里面写东西,也都可以从里面读东西。写就是
在队列末尾添加,读就是在队头删除。

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

3. 默认情况下,管道写入以后,就会被阻止,直到读取他的程序读取把数据读完。而读取线程也会被阻止,
直到有进程向管道写入数据。当然,你可以改变这样的默认属性,用stream_set_block 函数,设置成非阻断模式。

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

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

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

人气教程排行