APUE:进程间通信
Posted
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了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:进程间通信的主要内容,如果未能解决你的问题,请参考以下文章