ホームページ  >  記事  >  バックエンド開発  >  PHPマルチスレッドパイプライン通信の応用

PHPマルチスレッドパイプライン通信の応用

*文
*文オリジナル
2017-12-25 17:06:421735ブラウズ

この記事では、PHP マルチスレッド プログラミングにおけるパイプライン通信を主に紹介し、パイプライン通信の原理と使用法を例を用いて分析します。これが皆様のパイプライン通信の理解に役立つことを願っています。

1 つのスレッドが個人の英雄主義である場合、複数のスレッドは集団主義です。あなたはもはや孤独なレンジャーではなく、指揮者です。

パイプライン通信:
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 = &#39;pipe&#39;, $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, &#39;w&#39;);
    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, &#39;w&#39;);
    fwrite($w_pipe, $data);
    fclose($w_pipe);
  }
 
  function close_write()
  {
    return fclose($this->w_pipe);
  }
/////////////////////////////////////////////////////////
/// 读管道相关函数开始
////////////////////////////////////////////////////////
  function open_read()
  {
    $this->r_pipe = fopen($this->fifoPath, &#39;r&#39;);
    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, &#39;r&#39;);
    $data = &#39;&#39;;
    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 マルチスレッドの素晴らしい使い方を理解する

PHP マルチスレッドの詳細な説明

PHP プロセス間通信 - 有名なパイプ

以上がPHPマルチスレッドパイプライン通信の応用の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。