>  기사  >  백엔드 개발  >  PHP 다중 스레드 프로그래밍 파이프 통신 예제 분석_php 기술

PHP 다중 스레드 프로그래밍 파이프 통신 예제 분석_php 기술

WBOY
WBOY원래의
2016-05-16 20:21:371129검색

이 기사의 예에서는 PHP 다중 스레드 프로그래밍에서 파이프라인 통신의 사용법을 설명합니다. 참고할 수 있도록 모든 사람과 공유하세요. 구체적인 분석은 다음과 같습니다.

하나의 스레드가 개인의 영웅주의라면, 여러 스레드는 집단주의입니다. 당신은 더 이상 고독한 레인저가 아니라 지휘자입니다.

파이프 통신:
1. 파이프라인은 대기열로 생각할 수 있습니다. 다양한 스레드가 파이프라인에 내용을 쓰고 읽을 수 있습니다. 그냥
쓰세요 대기열 끝에 추가한다는 것은 대기열의 선두에서 삭제한다는 것을 의미합니다.

2. 파이프에는 일반적으로 크기가 있으며 기본값은 일반적으로 4K입니다. 즉, 내용이 4K를 초과하면 읽을 수만 있고 쓸 수는 없습니다.

3. 기본적으로 파이프에 쓴 후에는 파이프를 읽는 프로그램이 데이터 읽기를 완료할 때까지 차단됩니다. 그리고 읽기 스레드도 차단됩니다.
프로세스가 파이프에 데이터를 쓸 때까지. 물론 이 기본 속성을 변경하고 stream_set_block 함수를 사용하여 비차단 모드로 설정할 수 있습니다.

다음은 제가 패키징한 파이프라인 클래스입니다.(이 클래스 네이밍에 문제가 있어서 통일이 안되어 통일된 것으로 바꿀 시간이 없네요. 보통 테스트 코드를 먼저 작성하고 마지막에 패키징하는 편입니다. 이므로 명칭이 통일되지 않을 수 있습니다):

<&#63;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);
  }
}
&#63;>
 /*
有了这个类,就可以实现简单的管道通信了。*/

이 기사가 모든 사람의 PHP 프로그래밍 설계에 도움이 되기를 바랍니다.

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.