当前位置:  技术问答>linux和unix

进程同步问题,求指点

    来源: 互联网  发布时间:2017-05-30

    本文导语:  问题描述:生产者进程向数组添加100次数据,消费者从数组读取数据并求和,有fullid,emptyid,mutxid三个信号量,array,sum,set,get四个共享主存,array为共享数组,set记录生产者写的次数,get为消费者读的次数. 问题:每个进程...

问题描述:生产者进程向数组添加100次数据,消费者从数组读取数据并求和,有fullid,emptyid,mutxid三个信号量,array,sum,set,get四个共享主存,array为共享数组,set记录生产者写的次数,get为消费者读的次数.

问题:每个进程都运行不完整,好像semop对进程并没有阻塞

代码:
#include 
#include 
#include 
#include 
#include 
#include 
#include 
#include 

#define MAXSEM 5

int fullid;
int emptyid;
int mutxid;

int main()
{
pid_t prod,custoa,custob;
int shm_id,i = 0;
int flag = IPC_CREAT|IPC_EXCL|00666;
struct sembuf P = {0,-1,SEM_UNDO};
struct sembuf V = {0,1,SEM_UNDO};
union semun arg;

int *array;
int *sum;
int *set;
int *get;

int arr_id,sum_id,set_id,get_id;

arr_id = shmget(IPC_PRIVATE,1024,IPC_CREAT|IPC_EXCL);
sum_id = shmget(IPC_PRIVATE,1024,IPC_CREAT|IPC_EXCL);
set_id = shmget(IPC_PRIVATE,1024,IPC_CREAT|IPC_EXCL);
get_id = shmget(IPC_PRIVATE,1024,IPC_CREAT|IPC_EXCL);

// printf("create share memory successn");

array = (int *)shmat(arr_id,NULL,0);
sum = (int *)shmat(sum_id,NULL,0);
set = (int *)shmat(set_id,NULL,0);
get = (int *)shmat(get_id,NULL,0);

// printf("link successn");

fullid = semget(IPC_PRIVATE,1,flag);
emptyid = semget(IPC_PRIVATE,1,flag);
mutxid = semget(IPC_PRIVATE,1,flag);

arg.val = 0;
if(semctl(fullid,0,SETVAL,arg) == -1)
perror("semctl setval error");

arg.val = MAXSEM;
if(semctl(emptyid,0,SETVAL,arg) == -1)
perror("semctl setval error");

arg.val = 1;
if(semctl(mutxid,0,SETVAL,arg) == -1)
perror("semctl setval error");

// P = {0,-1,IPC_NOWAIT};
// V = {0,1,IPC_NOWAIT};
// printf("%dn",getpid());
prod = fork();
if(prod 

    
 
 

您可能感兴趣的文章:

  • 高手指点:不用JNI,如何在Java进程中新起一个JVM并在其中启动另一个Java进程。
  • shell进程退出,其子进程怎样才能不死,交给init进程管,谢谢,请指点下我写的程序
  • 请各位指点下嵌入式linux应用程序开发关于线程和进程的选用
  • 求高手指点进程监控问题
  • 关于控制并发进程数量和进程回收问题,请各位兄弟指点!急!!!!!!!
  • 高手请指点,怎么创建一个不会死的进程
  • linux 里有哪些内核与用户进程的通信方法? 请高手指点一下!谢谢!
  • linux下一个进程下面有多个线程的栈切换的问题,望高人指点下。
  • 用C编写一个多进程的程序,请各位大侠指点一下,不需要源代码,只想知道该怎样来设计程序的框架。在线等各位的帮助。谢谢。(急求)
  • 关于多进程问题,请各位兄弟指点!
  • 跪求大虾指点...进程通信
  • 课题中关于进程的问题,请高手指点啊!!
  • 为什么进程总是不停的收到SIGTTOU信号,请高手指点
  • 关于fork创建进程的问题,请各位指点!多谢!
  • linux进程管道通信C语言编程:程序有问题,请指点迷津
  • 有关部署守护进程的问题,请大家指点。
  • 关于vfork()问题,为什么其对父进程共享的变量的操作结果不是预期的?请高手指点,多谢了
  • 信号灯同步2个进程,一个进程如何主动给另一个进程发送通知?
  • 进程同步问题
  • 用信号量机制解决实际的三个进程同步问题
  • 关于进程同步
  • linux进程同步或互斥
  • 请问在子进程中变量如何与父进程同步(100)
  • 进程同步,用进程+SYS V信号量实现如下前趋图
  • linux下进程同步有mutex吗?
  • 两个不同的进程对共享内存中的变量读写,一般通过什么方式同步方便?
  • 请问pthread_mutex_lock()和pthread_mutex_unlock()可不可以用于对不同进程的线程进行同步。
  • 请问在单进程,多线程程序里,线程间使用IPC的信号量来同步,能行吗?
  • 求一个多进程之间的同步算法?
  • 进程数据同步:消息队列还是共享内存+信号
  • 进程间通信:pthread_cond使用在线程间,我要进程间条件同步(没有情缘关系的进程),采用什么方呢?也就是说我要在UNIX实现WIN32上命名Event的功能
  •  
    本站(WWW.169IT.COM)旨在分享和传播互联网科技相关的资讯和技术,将尽最大努力为读者提供更好的信息聚合和浏览方式。
    本站(WWW.169IT.COM)站内文章除注明原创外,均为转载、整理或搜集自网络。欢迎任何形式的转载,转载请注明出处。












  • 相关文章推荐
  • linux僵尸(zombie)进程介绍及清除
  • 进程Afork进程B,进程Bfor进程C,如果进程C退出发出SIGCHLD,A进程是否可以收到
  • Ubuntu查看内存,进程相关命令介绍
  • 如果一个server进程要fork许多子进程,但不等待子进程终止,也不希望子进程结束后处于僵进程状态直到父进程终止。请问可采用什么方法实现
  • linux下进程占用内存空间详解
  • 在多进程中父进程frok子进程,怎样让子进程自举,脱离父进程,而且父进程不退出
  • Linux进程的内核栈和用户栈概念,相互关系及切换过程
  • fock()开出的子进程的进程ID是否进程ID都大于父进程的?
  • android 4.0 托管进程介绍及优先级和回收机制
  • 父进程等待子进程n秒,如果子进程正常退出,父进程立即继续向下执行,如果子出现进程故障一直不退出,父进程等待n秒后继续向下执行,请问
  • linux下进程间通信:共享内存原理及具体用法举例(基于c/c++语言)
  • 多进程问题 子进程读取内容 读完挂起,父进程写 写入后唤醒子进程
  • 一个进程首先监听一个端口,等到有连接了就新开一个进程,让新进程来处理后面的通讯。请问母进程中已经打开了端口,子进程怎么来使用同一
  • 我在一个父进程中,生成了4个子进程,子进程的优先级是一样的。我现在想结束子进程。该如何做?
  • 子进程wait/waitpid//子进程不结束,父进程会等待子进程吗?
  • 在一个进程中我定义了几个全局变量,然后我又fork了几个子进程,子进程中是否可以各自对全局变量进行修改,如果各子进程都对其进行修改,
  • 怎样一次杀掉父进程创建的所有子进程?我在父进程中用kill(0,SIGKILL),结果父进程也给干掉了,参数0难道不是表示除自己外的所有同uid的进
  • 进程创建进程组后,然后创建该组中的进程,然后终止。这里的终止....?
  • 如何实现子进程根据父进程的信号来确定是否终止子进程???
  • 高手请教!linux怎样通过pid获取进程信息,如:进程名、进程状态等?
  • 如何通过进程号获得进程的一些信息,例如:进程运行的目录


  • 站内导航:


    特别声明:169IT网站部分信息来自互联网,如果侵犯您的权利,请及时告知,本站将立即删除!

    ©2012-2017,169IT.COM,E-mail:www_169it_com#163.com(请将#改为@)

    浙ICP备11055608号