• 技术文章 >后端开发 >php教程

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

    2016-05-31 13:13:33原创290
    本文实例讲述了PHP多线程编程之管道通信用法。分享给大家供大家参考。具体分析如下:

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

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

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

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

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

    <?php
    class Pipe
    {
      public $fifoPath;
      private $w_pipe;
      private $r_pipe;
     
      /**
       * 自动创建一个管道
       *
       * @param string $name 管道名字
       * @param int $mode 管道的权限,默认任何用户组可以读写
       */
      function __construct($name = 'pipe', $mode = 0666)
      {
        $fifoPath = "/tmp/$name." . posix_getpid();
        if (!file_exists($fifoPath)) {
          if (!posix_mkfifo($fifoPath, $mode)) {
            error("create new pipe ($name) error.");
            return false;
          }
        } else {
          error( "pipe ($name) has exit.");
          return false;
        }
        $this->fifoPath = $fifoPath;
      }
    ///////////////////////////////////////////////////
    // 写管道函数开始
    ///////////////////////////////////////////////////
      function open_write()
      {
        $this->w_pipe = fopen($this->fifoPath, 'w');
        if ($this->w_pipe == NULL) {
          error("open pipe {$this->fifoPath} for write error.");
          return false;
        }
        return true;
      }
     
      function write($data)
      {
        return fwrite($this->w_pipe, $data);
      }
     
      function write_all($data)
      {
        $w_pipe = fopen($this->fifoPath, 'w');
        fwrite($w_pipe, $data);
        fclose($w_pipe);
      }
     
      function close_write()
      {
        return fclose($this->w_pipe);
      }
    /////////////////////////////////////////////////////////
    /// 读管道相关函数开始
    ////////////////////////////////////////////////////////
      function open_read()
      {
        $this->r_pipe = fopen($this->fifoPath, 'r');
        if ($this->r_pipe == NULL) {
          error("open pipe {$this->fifoPath} for read error.");
          return false;
        }
        return true;
      }
      function read($byte = 1024)
      {
        return fread($this->r_pipe, $byte);
      }
      function read_all()
      {
        $r_pipe = fopen($this->fifoPath, 'r');
        $data = '';
        while (!feof($r_pipe)) {
          //echo "read one K\n";
          $data .= fread($r_pipe, 1024);
        }
        fclose($r_pipe);
        return $data;
      }
      function close_read()
      {
        return fclose($this->r_pipe);
      }
      /**
       * 删除管道
       *
       * @return boolean is success
       */
      function rm_pipe()
      {
        return unlink($this->fifoPath);
      }
    }
    ?>
     /*
    有了这个类,就可以实现简单的管道通信了。*/

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

    声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn核实处理。
    上一篇:php实现将数组转换为XML的方法_PHP 下一篇:php计算指定目录下文件占用空间的方法_PHP
    千万级数据并发解决方案

    相关文章推荐

    • Classes and Objects in PHP5-面向对象编程 [1]_PHP教程• nginx支持pathinfo模式• php 不使用js实现页面跳转_php技巧• PHP项目开发中最常用的自定义函数整理_php技巧• php自动跳转中英文页面_php技巧
    1/1

    PHP中文网