首页 > 代码库 > APUE:进程间通信

APUE:进程间通信

管道

半双工。一般由父进程创建,用于父子进程间、子进程间通信。匿名,一对一。

// fd[0] 只读
// fd[1] 只写
int pipe (int fd[2]);

简单执行命令行,并读写标准输入输出。

// 如果 modes == "r",返回标准输出
// 如果 modes == "w",返回标准输入
FILE *popen (const char *__command, const char *__modes);
int pclose (FILE *__stream);

 

FIFO(命名管道)

用法:服务端创建一个 FIFO,其它任何进程都可以向其写入数据,服务端读到数据后处理。可以一读多写。写数据的大小小于 PIPE_BUF 时为原子操作。

类似文件操作,包括用户/组/其它人的读写执行权限,删除需要 unlink。

int mkfifo (const char *__path, __mode_t __mode);
int mkfifoat (int __fd, const char *__path, __mode_t __mode);

  

POSIX 信号量

匿名信号量:同一进程不同线程使用。如果需要跨进程,需要将信号量结构体进行内存映射。

命名信号量:可以直接在不同进程中使用。

// 匿名信号量
int sem_init (sem_t *__sem, int __pshared, unsigned int __value)
int sem_destroy (sem_t *__sem);

// 打开已有信号量,oflag = 0
// 如果需要在信号量不存在时创建,oflag = O_CREAT,且必须指定 mode 的文件访问权限和 value 信号量初始值(0~SEM_VALUE_MAX)
sem_t *sem_open (const char *__name, int __oflag, ... /* mode_t mode, unsigned int value */);

int sem_close (sem_t *__sem);

// 没有人使用信号量后,自动删除
int sem_unlink (const char *__name);

// P
int sem_wait (sem_t *__sem);
int sem_timedwait (sem_t *__restrict __sem, const struct timespec *__restrict __abstime);
int sem_trywait (sem_t *__sem);

// V
int sem_post (sem_t *__sem);

 

共享存储

多个进程用相同的 key 使用 sh* 系列函数。

/* The following System V style IPC functions implement a shared memory
   facility.  The definition is found in XPG4.2.  */

/* Shared memory control operation.  */
extern int shmctl (int __shmid, int __cmd, struct shmid_ds *__buf) __THROW;

/* Get shared memory segment.  */
extern int shmget (key_t __key, size_t __size, int __shmflg) __THROW;

/* Attach shared memory segment.  */
extern void *shmat (int __shmid, const void *__shmaddr, int __shmflg)
     __THROW;

/* Detach shared memory segment.  */
extern int shmdt (const void *__shmaddr) __THROW;

  

 

APUE:进程间通信