PHP多線程編程之管道通信實例

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)

{