首页 > 代码库 > 进程间通信
进程间通信
- 管道
- popen 启动shell命令调用pipe
-
- FILE* popen(const char* command, const char* open_mode)//mode 表示读或写。
- pipe
-
- pipe(int file_descriptor[2])
- 通过exec调用,将文件描述符以参数的形式传给子进程。
- FIFO
-
- FIFO以命名文件的形式存在,pipe只是关联两个文件描述符。
- int mkfifo(const char* filename, mode_t mode);
- open(congst char* path, O_RDNOLY|O_NONBLOCK)
- open 的第二个参数:详细说明:P459面
- 信号量(进出临界区控制)
-
- int semget(key_t key, int num_sems, int sem_flags);其他函数将使用这个返回值
- int semctl(int sem_id, int sem_num, int command,...);设置临界区属性
- int semop(int sem_id, struct sembuf* sem_ops, size_t num_sem_ops);进去和离开临界
- 共享内存
- 共享内存是由IPC为进程创建的一个特殊的地址范围,它将出现在该进程的地址空间中。其他进程可以将同一段共享内存连接到它们自己的地址空间中,就像是它们自己malloc一样。
- int shmget(key_t key, size_t size, int shmflg);//创建
- void* shmat(int shm_id, const void* shm_addr, int shmflg);//将创建的共享内存关联到自己的进程中来
- int shmdt(const void* shm_addr);//分离共享内存
- int shmctl(int shm_id, int commond, struct shmid_ds*buf);
- 消息队列
-
- int msgget(key_t key, int msgflg);//创建获取一个消息队列
- int msgsnd(int msgid, const void* msg_ptr, size_t msg_gz, int msgflg);
- int msgrcv(int msqid, void* msg_ptr, size_t msg_sz, long int msgtype, int msgflg);
- int msgctl(int msqid, int commond, struct msqid_ds* buf);
进程间通信
声明:以上内容来自用户投稿及互联网公开渠道收集整理发布,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任,若内容有误或涉及侵权可进行投诉: 投诉/举报 工作人员会在5个工作日内联系你,一经查实,本站将立刻删除涉嫌侵权内容。