进程同步示例代码(依据信号量达到同步)

</pre><pre name="code" class="cpp">#include <iostream>
#include <signal.h>
#include <wait.h>
#include <errno.h>


using namespace std;


static volatile sig_atomic_t sigflag;
static sigset_t newmask,oldmask,zeromask;


//信号处理程序
static void sig_usr(int signo)
{
      sigflag=1;
}


//注册信号处理程序,并阻塞用户信号SIGUSR1和SIGUSR2
void TELL_WAIT(void)
{
      if(signal(SIGUSR1,sig_usr)==SIG_ERR)
      {
            cout<<"signal(SIGUSR1) error"<<endl;
      }
      if(signal(SIGUSR2,sig_usr)==SIG_ERR)
      {
            cout<<"signal(SIGUSR2) error"<<endl;
      }


      sigemptyset(&zeromask);
      sigemptyset(&newmask);
      sigaddset(&newmask,SIGUSR1);
      sigaddset(&newmask,SIGUSR2);


      if(sigprocmask(SIG_BLOCK,&newmask,&oldmask)<0)
      {
            cout<<"SIG_BLOCK error"<<endl;
      }
}


//子进程在延缓信号函数处阻塞,但进程并不阻塞任何信号,
//等待父进程发信号和信号处理函数返回后,复原阻塞信号状态,并进程继续运行
void WAIT_PARENT(void)
{
      while(sigflag==0)
      {
             if(sigsuspend(&zeromask)<0)
      {
            if(errno!=EINTR)
            cout<<"sigsuspend error"<<endl;
      }
      }
      sigflag=0;
      if(sigprocmask(SIG_SETMASK,&oldmask,NULL)<0)
      {
            cout<<"SIG_SETMASK error"<<endl;
      }


}


//给父进程发信号
void TELL_PARENT(pid_t pid)
{
      kill(pid,SIGUSR1);
}




//父进程在延缓信号函数处阻塞,但进程并不阻塞任何信号,
//等待子进程发信号和信号处理函数返回后,复原阻塞信号状态,并进程继续运行
void WAIT_CHILD(void)
{
      while(sigflag==0)
      {
             if(sigsuspend(&zeromask)<0)
      {
             if(errno!=EINTR)
            cout<<"sigsuspend error"<<endl;
      }
      }
      sigflag=0;
      if(sigprocmask(SIG_SETMASK,&oldmask,NULL)<0)
      {
            cout<<"SIG_SETMASK error"<<endl;
      }


}


//给子进程发送信号
void TELL_CHILD(pid_t pid)
{
      kill(pid,SIGUSR2);
}




int main()
{
      pid_t pid;
      TELL_WAIT();
      //以下两行代码不能写入循环,因为这是初始设定,不阻塞父进程,阻塞子进程
      sigflag=1;
      WAIT_CHILD();
      if((pid=fork())<0)
      {
            cout<<"fork error"<<endl;
      }else if(pid==0)
      {
            for(int i=0;i<10;++i)
            {
                  WAIT_PARENT();
                  cout<<"c:"<<i<<endl;
                  TELL_PARENT(getppid());
            }
      }else
      {
            cout<<"p:"<<0<<endl;
            TELL_CHILD(pid);
            for(int i=1;i<10;++i)
            {
                  WAIT_CHILD();
                  cout<<"p:"<<i<<endl;
                  TELL_CHILD(pid);
            }
            int stat;
            wait(&stat);
      }


    return 0;
}


  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值