linux信号量通讯失败,Linux C++ 通过信号量进行跨进程通讯

最近帮着同事搞了一下嵌入式的gtk界面, 中间有用到系统signal来进行进程通讯, 做个简单的记录

在使用linux系统信号量之前需要先了解一下信号量基础知识, 这里给出一个参考博文, 讲的很仔细 : https://www.cnblogs.com/taobataoma/archive/2007/08/30/875743.html

下面是我摘录的一些个人认为的关键点 :

软中断信号(signal,又简称为信号)用来通知进程发生了异步事件。进程之间可以互相通过系统调用kill发送软中断信号

内核也可以因为内部事件而给进程发送信号,通知进程发生了某个事件

注意,信号只是用来通知某进程发生了什么事件,并不给该进程传递任何数据

到信号的进程对各种信号有不同的处理方法, 处理方法可以分为三类:

第一种是类似中断的处理程序,对于需要处理的信号,进程可以指定处理函数,由该函数来处

第二种方法是,忽略某个信号,对该信号不做任何处理,就象未发生过一样

第三种方法是,对该信号的处理保留系统的默认值,这种缺省操作,对大部分的信

号的缺省操作是使得进程终止

了解了信号量基础之后, 我们来看一下如何发送信号

通常情况下, 使用 kill 命令可以向指定进程发送指定信号, 对于不同的环境发送的信号是不同的, 使用 kill -l 可以查看能够发送信号

其中有 SIGUSR1 和 SIGUSR2 两个信号提供给用户, 作为自定义信号, 那么如果想进行进程间通讯, 只需要在一个进程里调用 kill 命令, 将指定的信号发送给另一个进程, 并在另一个进程中注册对应信号的回调函数即可

下面上代码, 分享我的实现方式

首先是发送信号的进程

1 #include

2 #include

3 #include

4 #include

5

6 #include

7 #include

8

9 //执行命令并返回结果

10 void get_cmd_result(const std::string &_cmd, std::string &_result)11 {12 FILE *_cmd_result = popen(_cmd.c_str(), "r");13

14 char *buf = new char[256];15 memset(buf, 0, sizeof(buf));16

17 fread(buf, 1, sizeof(buf), _cmd_result);18 _result =buf;19

20 pclose(_cmd_result);21 deletebuf;22 buf =nullptr;23 }24

25 //向给定进程发送SIGUSR1信号

26 void send_proc_SIGUSR1(const std::string &proc_name)27 {28 std::string _cmd = "ps -a | grep" + proc_name + "| grep -v grep | awk '{print $1}'";29 std::stringproc_pid;30

31 get_cmd_result(_cmd, proc_pid);32 std::cout << "proc_pid =" << proc_pid <<:endl>

34 //system会调用 /bin/sh ,sh环境的信号量与bash环境的信号量语法不同

35 std::string emit_SIGUSR1_to_proc = "kill -USR1" +proc_pid;36 std::cout << "execute cmd :" << emit_SIGUSR1_to_proc <<:endl>

38 system(emit_SIGUSR1_to_proc.c_str());39 }40

41 intmain()42 {43 while (true)44 {45 send_proc_SIGUSR1("sig_wait");46 sleep(2);47 }48

49 return 0;50 }

下面是接收信号的进程

1 #include

2 #include

3

4 #include

5

6 voidsignal_handler()7 {8 std::cout << "get signal : SIGUSR1" <<:endl>

11 intmain()12 {13 signal(SIGUSR1, (sighandler_t)signal_handler);14

15 while(true)16 {17 std::cout << "waiting signal..." <<:endl sleep>

21 return 0;22 }

这里需要注意的点就是, sh和bash环境下, kill 命令发送信号量的格式不太一样, 具体大家可以用/bin/sh 试一下 kill -l

最后将两段代码分别编译生成两个程序 sig_send 和 sig_wait 并执行, 结果如下

sig_send :

sig_wait :

以上, , 如有疏漏, 欢迎指正

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 共享内存是一种进程间通信的机制,它允许多个进程访问同一块内存区域。通过将内存区域映射到多个进程的地址空间中,实现了数据的共享。这种方式可以提高进程间的通信效率,避免了复制数据的开销。 信号量也是一种进程间通信的方式,它可以用来协调多个进程对共享资源的访问。信号量可以用来控制进程的执行顺序,避免出现竞争条件和死锁。通过对信号量的操作(如等待、唤醒等),进程可以申请或释放共享资源,并保证资源的独占性。 在使用共享内存时,需要使用信号量来保证对内存区域的正确访问。例如,当一个进程需要修改共享内存中的数据时,它需要先获取一个信号量,并在操作完成后释放信号量,以防止其他进程同时访问同一块内存区域。 综合来看,共享内存和信号量是一种相互配合的进程间通信方式。共享内存提供了高效的数据共享机制,而信号量用于对共享资源的访问进行协调和控制。在实际应用中,可以使用这两种方式来实现进程间的数据共享和同步。 ### 回答2: 共享内存和信号量进程间通信的两种常用方式。 共享内存是一种在多个进程之间共享内存区域的方式。多个进程可以通过映射到同一块内存区域的方式来同时访问数据,从而实现数据的共享和交互。使用共享内存可以提高进程间的数据传递效率,尤其适用于需要频繁读写大量数据的场景。但是由于多进程共享同一块内存,必须通过信号量等机制来协调不同进程对内存的访问,避免数据一致性问题。 信号量是一种用于进程同步和互斥的机制。它可以保证多个进程按照一定顺序执行,并避免竞争条件导致的数据错误。信号量的基本概念是一个计数器,多个进程可以通过对信号量的操作来实现对共享资源的访问控制。当进程需要使用某个共享资源时,它首先会检查信号量的值,如果满足条件,就可以访问资源并将信号量的值减一;否则,进程将等待,直到有其他进程释放资源并增加信号量的值。使用信号量可以有效避免资源的竞争和死锁问题。 综上所述,共享内存和信号量是两种常用的进程间通信方式。共享内存用于实现多个进程之间的数据共享和交互,提高效率;而信号量用于实现进程之间的同步和互斥,保证资源的正确访问。在实际应用中,需要根据具体场景需要选择合适的通信方式。 ### 回答3: c 共享内存是一种进程间通信的机制,通过将一块内存区域映射到多个进程的地址空间中,实现多个进程之间的数据共享。共享内存可以提高进程间通信的效率,因为数据在进程间直接传递,不需要复制和拷贝的操作。 共享内存可以通过操作系统提供的相关函数来实现,比如在Linux中可以使用shmget、shmat等函数来创建和关联共享内存区域。多个进程可以在同一块共享内存区域中读写数据,进程之间进行协调和同步。 而信号量是一种用于进程同步和互斥的机制,通过对共享资源的访问进行控制,防止多个进程同时对同一资源进行读写,避免竞争条件的发生。 信号量可以用于进程间的互斥操作,保证只有一个进程可以访问某个资源;也可以用于进行进程间的同步操作,当一个进程完成某个任务后,可以通知另一个等待的进程开始执行。 在操作系统中,信号量通过操作系统提供的相关函数进行实现,比如在Linux中可以使用semget、semop等函数来创建和操作信号量。 在实际应用中,通常会同时使用共享内存和信号量来完成进程间的通信和同步操作,共享内存提供数据共享的机制,而信号量提供对共享资源的控制和同步

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值