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

进程间通信

  • 管道
  • 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);

进程间通信