이 기사의 예에서는 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 프로그래밍 설계에 도움이 되기를 바랍니다.