有名信号量和共享内存实现同步聊天
2017-07-17 20:43
337 查看
有名信号量和共享内存实现同步聊天
共享内存是最为高效的进程间通信方式,可直接读写内存,不需要任何数据的拷贝,因此效率高。
共享内存创建步骤:
1、创建或打开共享内存 shmget函数实现
2、映射共享内存 shmat函数实现
3、撤销共享内存映射 shmdt函数实现
4、删除共享内存对象 shmctl函数实现
有名信号量:可实现进程间通信的同步
sem_open函数打开或创建
sem_wait函数和sem_post函数来使用
sem_close函数用来关闭有名信号量
sem_unlink函数用来删除有名信号量
以下是两个进程直接实现简单的聊天:
进程1:
共享内存是最为高效的进程间通信方式,可直接读写内存,不需要任何数据的拷贝,因此效率高。
共享内存创建步骤:
1、创建或打开共享内存 shmget函数实现
2、映射共享内存 shmat函数实现
3、撤销共享内存映射 shmdt函数实现
4、删除共享内存对象 shmctl函数实现
有名信号量:可实现进程间通信的同步
sem_open函数打开或创建
sem_wait函数和sem_post函数来使用
sem_close函数用来关闭有名信号量
sem_unlink函数用来删除有名信号量
以下是两个进程直接实现简单的聊天:
进程1:
#include <stdio.h> #include <sys/ipc.h> #include <sys/shm.h> #include <sys/types.h> #include <string.h> #include <signal.h> #include <stdlib.h> #include <fcntl.h> #include <sys/stat.h> #include <semaphore.h> char *p; sem_t *sem1,*sem2; void fun(int sig) { shmdt(p); sem_close(sem1); sem_close(sem2); sem_unlink("aaa"); sem_unlink("bbb"); exit(0); return; } int main() { sem1 = sem_open("aaa",O_CREAT,0666,1); if(SEM_FAILED == sem1) { perror("sem_open error!"); return -1; } sem_t * sem2 = sem_open("bbb",O_CREAT,0666,0); if(SEM_FAILED == sem2) { perror("sem_open error!"); return -1; } key_t key = ftok(".",1); if(key < 0) { perror("ftok error!"); return -1; } int shmID = shmget(key,100,IPC_CREAT | 0666); if(shmID < 0) { return -1; } p = shmat(shmID,NULL,0); if(p == (char *)-1) { perror("shmat error!"); return -1; } *p = 0; printf("*********小喵*********\n"); while(1) { sem_wait(sem1); signal(SIGINT,fun); if(*p != 0) { printf("收到:%s\n",p); } memset(p,0,100); gets(p); sem_post(sem2); } }
进程2:
#include <stdio.h> #include <sys/ipc.h> #include <sys/shm.h> #include <sys/types.h> #include <signal.h> #include <string.h> #include <stdlib.h> #include <fcntl.h> #include <sys/stat.h> #include <semaphore.h> char *p; int shmID; sem_t *sem1,*sem2; void fun(int sig) { shmdt(p); shmctl(shmID,IPC_RMID,NULL); sem_close(sem1); sem_close(sem2); sem_unlink("aaa"); sem_unlink("bbb"); exit(0); return; } int main() { sem1 = sem_open("aaa",O_CREAT,0666,1); if(SEM_FAILED == sem1) { perror("sem_open error!"); return -1; } sem2 = sem_open("bbb",O_CREAT,0666,0); if(SEM_FAILED == sem2) { perror("sem_open error!"); return -1; } key_t key = ftok(".",1); if(key < 0) { perror("ftok error!"); return -1; } shmID = shmget(key,100,IPC_CREAT | 0666); if(shmID < 0) { return -1; } p = shmat(shmID,NULL,0); if(p == (char *)-1) { perror("shmat error!"); return -1; } printf("*******小汪*********\n"); while(1) { sem_wait(sem2); signal(SIGINT,fun); printf("收到:%s\n",p); memset(p,0,100); gets(p); sem_post(sem1); } }
以上是实现简单的两个进程聊天,进程1先发出消息由进程2接收,当收到Ctrl+c信号后聊天结束并且删除有名信号量退出
感谢阅读!!!
相关文章推荐
- 使用共享实现两个进程之间的聊天-使用有名信号量实现同步
- 共享内存多进程间通信,进程间同步使用信号量来实现
- 共享内存多进程间通信,进程间同步使用信号量来实现
- linux多线程【8】mmap实现父子进程的共享内存通信,用信号量同步
- 进程间共享内存(信号量实现同步)
- 进程间共享内存(信号量实现同步)
- Linux下通过共享内存进行进程间通信,进程间同步使用信号量来实现
- linux基于信号量同步的共享内存IPC实现
- Linux下通过共享内存进行进程间通信,进程间同步使用信号量来实现
- Linux下利用信号量函数和共享内存函数和C语言实现生产者消费者问题
- linux基础编程 共享内存 通过消息队列实现同步 shmget
- <转>linux操作系统编程——共享内存读写(采用信号量进行同步互斥)
- linux操作系统编程——共享内存读写(采用信号量进行同步互斥)
- linux 实现共享内存同步
- linux实现共享内存同步的四种方法
- 实现共享内存同步的四种方法
- Linux进程通信(无名管道,有名管道,共享内存)的实现
- Linux下用信号量实现对共享内存的访问保护
- Linux进程同步与通讯:共享内存和信号量的使用
- 进程间通信与同步---共享内存和信号量编程简介