关闭

linux进程间的通信--信号量同步

标签: linux进程间通信信号量同步
869人阅读 评论(0) 收藏 举报
分类:

1.核心理论

  • 进程的同步:是指一组并发的进程互相合作互相等待,使得各进程按照一定的顺序执行的过程叫做进程同步。

  • 同步与互斥的区别:同步时信号量初始值为0,互斥时信号量初始值大于0。
    解释:如果用信号量互斥的话,必须是生产者进程先执行。如果采用信号量同步的话,那么那么生产者和消费者的执行顺序不影响结果

2.进程同步编程实例

  • 消费者与生产者的关系
    生产者进程:创建一个文件,向文件中写入字符,二者之间穿插一些休息
    消费者进程:该进程在生产者休息期间,读取文件内容,导致中间出现一些问题。
    简单来说就是必须要先生产完成,然后才能消费。

  • 生产者完成任务是才释放信号量。

  • producter.c

#include <stdio.h>
#include <sys/types.h>
#include <sys/stat.h>   
#include <fcntl.h>
#include <unistd.h>
#include <sys/ipc.h>
#include <sys/sem.h>

void main()
{
     int fd;
     key_t key;    
     int semid;
     struct sembuf sops;

     //创建一个键值
     key = ftok("home",1);

     //创建一个信号量
     semid = semget(key,1,IPC_CREAT);

     semctl(semid,0,SETVAL,0);

     fd = open("./pro.txt",O_RDWR|O_CREAT|O_APPEND,0777);

     sleep(15);

     write(fd,"welcome,linux!",14);

     //释放信号量
     sops.sem_num = 0;
     sops.sem_op = 1;
     sops.sem_flg = SEM_UNDO;
     semop(semid,&sops,1);

     close(fd);
}
  • consumer.c
#include <stdio.h>
#include <unistd.h>
#include <stdlib.h>
#include <sys/types.h>
#include <sys/ipc.h>
#include <sys/sem.h>

void main()
{
     key_t key;
     int semid;
     int ret;
     struct sembuf sops;

     key = ftok("home",1);//创建一个键值

     semid = semget(key,1,IPC_CREAT);//获取信号量
               //IPC_CREAT命令如果键值不存在就创建

     /*法一:通过轮寻查看信号量是否释放
     ret = semctl(semid,0,GETVAL);    
     printf("%d\n",ret);
     while(!(ret))
     ret = semctl(semid,0,GETVAL);     */

     //法二:采用信号量机制
     sops.sem_num = 0;//要操作的信号量序号
     sops.sem_op = -1;//设置为自减1
     sops.sem_flg = SEM_UNDO;//要操作的信号量序号
     semop(semid,&sops,1);//执行操作

     system("cp ./pro.txt ./temp");


}
0
0
查看评论
发表评论
* 以上用户言论只代表其个人观点,不代表CSDN网站的观点或立场

笔记:进程间通信——同步(互斥锁、读写锁、条件变量、信号量)以及Linux中的RCU

1.互斥锁 多个线程的IPC,需要同步,同步有隐式的和显示的: 比如unix提供的管道和FIFO,由内核负责同步,比如read发生在write之前,那么read就会被内核阻塞,这中同步是由内核负责的,...
  • yyf_it
  • yyf_it
  • 2016-06-20 20:17
  • 1119

Linux进程同步之POSIX信号量

POSIX信号量是属于POSIX标准系统接口定义的实时扩展部分。在SUS(Single UNIX Specification)单一规范中,定义的XSI IPC中也同样定义了人们通常称为System V...
  • anonymalias
  • anonymalias
  • 2013-07-01 22:14
  • 10510

Linux多线程——使用信号量同步线程

信号量、同步这些名词在进程间通信时就已经说过,在这里它们的意思是相同的,只不过是同步的对象不同而已。但是下面介绍的信号量的接口是用于线程的信号量,注意不要跟用于进程间通信的信号量混淆。相似地,线程同步...
  • ljianhui
  • ljianhui
  • 2013-09-01 00:09
  • 44016

linux进程间的通信(C): 使用信号量进行同步的共享内存机制

一、简介 共享内存为在多个进程之间共享和传递数据提供了一种有效的方式。 但它本身并未提供同步机制。 在实际编程中,可以使用   信号量,   传递消息(使用管道或IPC消息),   生成信...
  • u013889753
  • u013889753
  • 2014-11-05 08:50
  • 539

linux进程间的通信(C): 使用信号量进行同步的共享内存机制

一、简介 共享内存为在多个进程之间共享和传递数据提供了一种有效的方式。 但它本身并未提供同步机制。 在实际编程中,可以使用   信号量,   传递消息(使用管道或IPC消息),   生成信...
  • fireroll
  • fireroll
  • 2013-02-25 06:07
  • 1173

Linux下通过共享内存进行进程间通信,进程间同步使用信号量来实现

Linux 环境下C编程指南,通过共享内存进行进程间通信的例子,进程间同步使用信号量来实现。、 书中有几个错误。。 使用说明:这是一个简单的服务器和客户端程序,如果启动程序时不带参数,则执...
  • cstn_kdlx
  • cstn_kdlx
  • 2012-02-08 10:34
  • 1762

笔记:进程间通信——同步(互斥锁、读写锁、条件变量、信号量)以及Linux中的RCU

1.互斥锁 多个线程的IPC,需要同步,同步有隐式的和显示的: 比如unix提供的管道和FIFO,由内核负责同步,比如read发生在write之前,那么read就会被内核阻塞,这中同步是由内核负责的,...
  • yyf_it
  • yyf_it
  • 2016-06-20 20:17
  • 1119

linux进程同步与通信(共享内存和信号量)

1)  设计编写以下程序,着重考虑其同步问题: a)        一个程序(进程)从客户端读入按键信息,一次将“一整行”按键信息保存到一个共享存储的缓冲区内并等待读取进程将数据读走,不断重复上面的操...
  • iamubbTing
  • iamubbTing
  • 2017-04-25 15:13
  • 175

线程同步3 ------ Linux进程间通信——使用信号量

这篇文章将讲述别一种进程间通信的机制——信号量。注意请不要把它与之前所说的信号混淆起来,信号与信号量是不同的两种事物。有关信号的更多内容,可以阅读我的另一篇文章:Linux进程间通信——使用信号。下面...
  • str999_cn
  • str999_cn
  • 2017-12-12 14:20
  • 58

共享内存多进程间通信,进程间同步使用信号量来实现

Linux 环境下C编程指南,通过共享内存进行进程间通信的例子,进程间同步使用信号量来实现。 代码 11-5 使用说明:这是一个简单的服务器和客户端程序,如果启动程序时不带参数,则执行服务...
  • joejames
  • joejames
  • 2014-07-27 11:06
  • 1158
    个人资料
    • 访问:50766次
    • 积分:1159
    • 等级:
    • 排名:千里之外
    • 原创:56篇
    • 转载:1篇
    • 译文:0篇
    • 评论:10条
    最新评论