1、进程间的通信
管道:单项流动pipe适用于半双工的单项流动,必须是父子关系进程间的通信。
有名管道:适用于非血缘关系的进程间通信。
消息队列:克服了信号传输信号少,管道只能传输无格式的字节流问题
共享内存:隐射一段被其他进程访问的内存。
信号量:作为同步进程的一种锁机制。
套接字:进程间的通信方式
信号:比较负责的通信方式。
学习使用pipe进程父子间和兄弟间的进程通信。
使用fifo进程无血缘关系的进程间通信
使用mmap进行无血缘和有血缘关系的进程间通信
2、管道
管道的本质时内核缓存区,管道的读端和写端都是阻塞的。内部使用的是环形队列实现的。
管道数据被读走后就不能再次被读出来。pipe只能用户血缘关系的进程间。
管道的默认大小是4k。
int pipe(int fn[2])
为什么管道只能在父子进程间通信?
因为管道的写入和读取的文件描述符,只能是父子进程才会共享相同的文件描述符。
3、内存映射区
使得磁盘文件与内存缓存区相映射,通过内核,将一个指定文件映射到内存区域,这个映射工作可以通过mmap函数实现。
void mmap(void *addr, size_t length, int prot, int flags, int fd, off_t off);
// 成功 : 返回创建的映射区首地址
// 失败 MAP_FAILED 宏
// 参数 addr :指定的映射的起始地址,通常为NULL, 由系统指定
// 参数 length:映射的内存的文件长度
// 参数 prot:映射的区的保护方式 常用的:读 PROT_READ 写:PROT_WRITE 读写
// 参数 flags MAP_SHARED: 写入映射区的数据会写回文件。MAP_PRIVATE:对映射区的写入操作会产生一个映射区的复制,对此区域的修改不会写回原文件。
// 参数 fd 由open返回的文件描述符
// 参数 offset 以文件开始的偏移量,必须是4K的整数倍,通常为零
4、匿名映射
mmap(NULL,4096,PROT_READ|PROT_WRITE,MAP_SHARED | MAP_ANNOYMOUS,-1,0);