PHP多執行緒程式設計之管道通訊例項
PHP多執行緒程式設計之管道通訊,例項分析了管道通訊的原理與相關使用技巧,具有一定參考借鑑價值,需要的`朋友可以參考下.
本文例項講述了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)
{