进程间通讯——笔记

本文介绍了进程间通信的五种主要方式:管道(包括匿名和命名管道)、信号量、消息队列、共享内存。这些通信机制允许不同进程之间交换数据,实现同步和互斥。管道提供了单向数据流,适用于父子进程;信号量用于进程同步;消息队列可存储结构化信息,支持无亲缘关系的进程通信;共享内存让多个进程直接访问同一块内存区域,速度最快但需要额外同步机制。
摘要由CSDN通过智能技术生成

进程系统进行资源分配和调度的基本单位。进程是一个实体,每个进程都有自己的地址空间,程序成为一个活动的实体后我们称之为线程。

进程通讯的方式:

1.管道(pipe)

半双工,数据单向流动,只能在父子程序中使用。

1 #include <unistd.h>

2 int pipe(int fd[2]);    // 返回值:若成功返回0,失败返回-1

2.有名管道    (named pipe,FIFO)

       半双工,允许在   无亲缘关系的程序中使用,先入先出。

1 #include <sys/stat.h>
2 // 返回值:成功返回0,出错返回-1
3 int mkfifo(const char *pathname, mode_t mode)

3.信号量(semaphore)

一个计数器,用于实现进程之间的互斥与同步。

#include <sys/sem.h>

// 创建或获取一个信号量组:若成功返回信号量集ID,失败返回-1

int semget(key_t key, int num_sems, int sem_flags);

// 对信号量组进行操作,改变信号量的值:成功返回0,失败返回-1

int semop(int semid, struct sembuf semoparray[], size_t numops);

// 控制信号量的相关信息

int semctl(int semid, int sem_num, int cmd, ...);

4.消息队列(message queue)

     消息的链接表,存放在内核中并由消息队列标识符标识。消息队列克服了信号传递信息少、管道只能承载无格式字节流以及缓冲区大小受限等缺点。

#include <sys/msg.h>

// 创建或打开消息队列:成功返回队列ID,失败返回-1

int msgget(key_t key, int flag);

// 添加消息:成功返回0,失败返回-1

int msgsnd(int msqid, const void *ptr, size_t size, int flag);

// 读取消息:成功返回消息数据的长度,失败返回-1

int msgrcv(int msqid, void *ptr, size_t size, long type,int flag);

// 控制消息队列:成功返回0,失败返回-1

int msgctl(int msqid, int cmd, struct msqid_ds *buf);

5.共享内存(Shared Memory)

       两个或多个进程共享某个给定的存储空间,最快的IPC,但是需要同步

#include <sys/shm.h>

// 创建或获取一个共享内存:成功返回共享内存ID,失败返回-1

int shmget(key_t key, size_t size, int flag);

// 连接共享内存到当前进程的地址空间:成功返回指向共享内存的指针,失败返回-1

void *shmat(int shm_id, const void *addr, int flag);

// 断开与共享内存的连接:成功返回0,失败返回-1

int shmdt(void *addr);

// 控制共享内存的相关信息:成功返回0,失败返回-1

int shmctl(int shm_id, int cmd, struct shmid_ds *buf);

参考链接:进程间的五种通信方式介绍 - moon-zhu - 博客园

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值