Maison > développement back-end > tutoriel php > PHP多线程编程之管道通信实例分析_php技巧

PHP多线程编程之管道通信实例分析_php技巧

WBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWB
Libérer: 2016-05-16 20:21:37
original
1233 Les gens l'ont consulté

本文实例讲述了PHP多线程编程之管道通信用法。分享给大家供大家参考。具体分析如下:

一个线程如果是个人英雄主义,那么多线程就是集体主义,你不再是一个独行侠,而是一个指挥家。

管道通信:
1. 管道可以认为是一个队列,不同的线程都可以往里面写东西,也都可以从里面读东西。写就是
在队列末尾添加,读就是在队头删除。
 
2. 管道一般有大小,默认一般是4K,也就是内容超过4K了,你就只能读,不能往里面写了。
 
3. 默认情况下,管道写入以后,就会被阻止,直到读取他的程序读取把数据读完。而读取线程也会被阻止,
   直到有进程向管道写入数据。当然,你可以改变这样的默认属性,用stream_set_block  函数,设置成非阻断模式。
 
下面是我分装的一个管道的类(这个类命名有问题,没有统一,没有时间改成统一的了,我一般先写测试代码,最后分装,所以命名上可能不统一):

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

27

28

29

30

31

32

33

34

35

36

37

38

39

40

41

42

43

44

45

46

47

48

49

50

51

52

53

54

55

56

57

58

59

60

61

62

63

64

65

66

67

68

69

70

71

72

73

74

75

76

77

78

79

80

81

82

83

84

85

86

87

88

89

90

91

92

93

94

95

96

97

98

99

100

<&#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;>

 /*

有了这个类,就可以实现简单的管道通信了。*/

Copier après la connexion

希望本文所述对大家的php程序设计有所帮助。

Étiquettes associées:
Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn
Tutoriels populaires
Plus>
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal