Linux怎么实现共享内存同步

发布时间:2022-01-27 16:08:07 作者:iii
来源:亿速云 阅读:288

本篇内容主要讲解“Linux怎么实现共享内存同步”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“Linux怎么实现共享内存同步”吧!

Linux怎么实现共享内存同步

方法一、利用POSIX有名信号灯实现共享内存的同步

有名信号量既可用于线程间的同步,又可用于进程间的同步。

两个进程,对同一个共享内存读写,可利用有名信号量来进行同步。一个进程写,另一个进程读,利用两个有名信号量semr, semw。semr信号量控制能否读,初始化为0。 semw信号量控制能否写,初始为1。

读共享内存的程序示例代码如下

 semr = sem_open("mysem_r", O_CREAT | O_RDWR , 0666, 0);
     if (semr == SEM_FAILED)
     {
         printf("errno=%d\n", errno);
         return -1;
     }
 
 •    semw = sem_open("mysem_w", O_CREAT | O_RDWR, 0666, 1);
 •    if (semw == SEM_FAILED)
 •    {
 •        printf("errno=%d\n", errno);
 •        return -1;
 •    }
 
 •    if ((shmid = shmget(key, MAXSIZE, 0666 | IPC_CREAT)) == -1)
 •    {
 •        perror("semget");
 •        exit(-1);
 •    }
 
 •    if ((shmadd = (char *)shmat(shmid, NULL, 0)) == (char *)(-1))
 •    {
 •        perror("shmat");
 •        exit(-1);
 •    }
 
 •    while (1)
 •    {
 •        em_wait(semr);
 •        printf("%s\n", shmadd);
 •        sem_post(semw);
 •    }
 
 写共享内存的程序示例代码如下
 
 。。。。。。
     //同读的程序
     while (1)
     {
         sem_wait(semw);
         printf(">");
         fgets(shmadd, MAXSIZE, stdin);
         sem_post(semr);
     }

方法二、利用POSIX无名信号灯实现共享内存的同步

POSIX无名信号量是基于内存的信号量,可以用于线程间同步也可以用于进程间同步。若实现进程间同步,需要在共享内存中来创建无名信号量。

因此,共享内存需要定义以下的结构体。

 typedef struct
     {
         sem_t semr;
         sem_t semw;
         char buf[MAXSIZE];
     }SHM;

读、写程序流程如下图所示。

Linux怎么实现共享内存同步

Linux怎么实现共享内存同步

方法三、利用System V的信号灯实现共享内存的同步

System V的信号灯是一个或者多个信号灯的一个集合。其中的每一个都是单独的计数信号灯。而Posix信号灯指的是单个计数信号灯

System V 信号灯由内核维护,主要函数semget,semop,semctl 。

一个进程写,另一个进程读,信号灯集中有两个信号灯,下标0代表能否读,初始化为0。 下标1代表能否写,初始为1。

程序流程如下:

Linux怎么实现共享内存同步

写的流程和前边的类似。

方法四、利用信号实现共享内存的同步

信号是在软件层次上对中断机制的一种模拟,是一种异步通信方式。利用信号也可以实现共享内存的同步。

思路:

reader和writer通过信号通信必须获取对方的进程号,可利用共享内存保存双方的进程号。

reader和writer运行的顺序不确定,可约定先运行的进程创建共享内存并初始化。

利用pause, kill, signal等函数可以实现该程序(流程和前边类似)。

到此,相信大家对“Linux怎么实现共享内存同步”有了更深的了解,不妨来实际操作一番吧!这里是亿速云网站,更多相关内容可以进入相关频道进行查询,关注我们,继续学习!

推荐阅读:
  1. 共享内存的实现
  2. linux怎么实现时间同步

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

linux

上一篇:php如何将索引数组转成关联数组

下一篇:jstat命令怎么使用

相关阅读

您好,登录后才能下订单哦!

密码登录
登录注册
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》