边学边干Linux内核指导(5)——进程间通讯
来源:互联网 发布:打击网络赌球 编辑:程序博客网 时间:2024/05/21 10:10
实现进程间通讯的方法:
1.管道
2.套接字
3.System V IPC-------1.message queue.2 semaphore 3.shared memory
关于共享内存的四个函数
shmget(key_t key, int size, int shmflg); //创建或者查找一个共享内存
void *shmat (int shmid, char *shmaddr, int shmflg); //返回一个地址空间
void *shmdt (char *shmaddr);
int shmctl(int shmid, int cmd, struct shmid_ds *buf); //对共享内存的属性进行管理
可以控制共享内存的访问权限,其实共享内存就是一个虚拟文件
系统配置参数SHMALL,SHMMAX,SHMMIN,SHMMNI 对共享内存的限制
fork(), exec()和exit()父子进程和共享内存的关系,fork:继承已经连接的,exec:都将被分离
内核维护一个shmid_ds数据结构,当shmat调用之后,会更新shm_atime 当前时间, shm_lpid 当前进程, shm_nattch++
如果shm_nattch为0,共享内存将被删除
IPC子系统对共享内存的管理,其实就是对数据结构shm_ids的成员变量数组entries的管理
实例
进程间用信号量和共享内存同步的例子
1.用信号量来同步,不用循环等待
2.一个信号量如果已经被lock,那么再去lock,会block。
3.信号量semop(),semctl()
为什么三个信号量就可以实现多个reader, writer。两个就业可以啊
释放一把锁时,会释放多个等在该锁上的多个进程,新的这把锁,是锁同时write或者read的情况
- 边学边干Linux内核指导(5)——进程间通讯
- 边学边干Linux内核指导(7)——进程同步
- 边学边干Linux内核指导(8)——进程调度
- Linux内核之进程间通讯
- 边学边干Linux内核指导(2)——内核时钟
- 边学边干Linux内核指导(3)——内核模块
- Linux—进程间通讯—信号量
- Linux进程间通讯—旗语
- Linux—进程间通讯方式总结
- 边学边干Linux内核指导(1)——理解Shell
- 边学边干Linux内核指导(4)——系统调用
- 边学边干Linux内核指导(6)——虚拟存储
- Linux进程间通讯
- linux进程间通讯
- Linux进程间通讯
- linux进程间通讯
- Linux进程间通讯
- Linux笔记_进程通讯——信号通讯
- 如何点击按钮弹出新窗口,输入数据后返回并刷新页面?
- Java and Regular Expression
- 突然提示:error loading MIDAS.DLL(注册dll的通用方式)
- 一升的眼泪,为了明天
- Flex 2.0.1即将发布
- 边学边干Linux内核指导(5)——进程间通讯
- 边学边干Linux内核指导(6)——虚拟存储
- 博客开张了~~
- 空间换时间,Memoization,单件模式,备忘录模式,之间的关系。
- linux内核之存储管理二
- 用.net实现远程获取其他网站页面内容
- java定时执行任务的三种方法
- 求救!!!关于C++该怎么学,怎么才能学好,有哪些方面的用途???
- “妖精”团队———阿里巴巴