线程同步(四)—— 信号

这篇是进程线程的博文的最后一篇了,至此进程线程的所有同步内容已经全部回顾完了。 其中信号和信号量看起来名字很像,实际上却是完全不一样的两个东西,信号和信号量在进程线程中都可以使用。而且使用方式也基本完全一样。 进程中的共享内存,线程中的互斥锁,条件变量。这些是独有的,但实际也能互相使用,《Unix网络编程》中对这些的总结是按需所用。

前面提到过线程回收,类似进程回收,线程回收的pthread_join也是接收子线程的销毁消息。 使用kill -l查看linux中的信号。 这次还是使用USR1信号作为用户的定义信号,进行线程的通信。 这块代码由于需要给指定的函数传入函数指针,为了消除this指针使用了几个static静态函数和静态成员。比较暴力QAQ

1 #include <sys/types.h>
 2 #include <pthread.h>  
 3 #include <unistd.h>
 4 #include <signal.h>
 5 #include <string.h>
 6 #include <iostream>
 7 #include <stdlib.h>
 8 
 9 using namespace std;
10 
11 class sigOp
12 {
13 public:
14     void addSigProcess(int sig,void (*func)(int));
15     void sendSig(const int sig, const int pid);
16 };
17 void sigOp::addSigProcess(int sig,void (*func)(int))
18 {
19     struct sigaction stuSig;
20     memset(&stuSig, '\0', sizeof(stuSig));
21     stuSig.sa_handler = func;
22     stuSig.sa_flags |= SA_RESTART;
23     sigfillset(&stuSig.sa_mask);
24     sigaction(sig, &stuSig, NULL);
25 }
26 void sigOp::sendSig(const int sig, const int pid)
27 {
28     pthread_kill(pid, sig);
29     cout<<"send!"<<endl;
30 }
31 
32 class ThreadInterface
33 {
34 public:
35     void CreateThread(void* (*func)(void *),void *threadID);
36     static void WaitThread(int);
37 private:
38     static pthread_t m_pTread;   //给静态函数使用
39 };
40 pthread_t ThreadInterface::m_pTread;//类外实例静态成员
41 
42 void ThreadInterface::CreateThread(void* (*func)(void *),void *threadID)
43 {
44     pthread_create(&m_pTread, NULL, func, threadID); 
45 }
46 
47 void ThreadInterface::WaitThread(int)
48 {
49     pthread_join(m_pTread, NULL);    
50 }
51 
52 class Service
53 {
54 public:
55     static void* run(void *threadID)
56     {
57         pthread_t *pTreadID = reinterpret_cast<pthread_t *>(threadID);
58         pthread_kill(*pTreadID, SIGUSR1);
59         
60     }
61     static void recSig(int)
62     {
63         cout<<"rev sig!"<<endl;
64     }
65 };
66 
67 int main()
68 {
69     Service Srv;
70     ThreadInterface Thread;
71     
72     sigOp sig;
73     sig.addSigProcess(SIGUSR1, Srv.recSig);
74     sig.addSigProcess(SIGCHLD, Thread.WaitThread);
75 
76     pthread_t selfID = pthread_self();    
77     Thread.CreateThread(&Srv.run, &selfID);
78 
79     sleep(5);
80     return 0;
81 }

测试结果:

在主线程收到其他线程发出的信号!

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

发表于

我来说两句

0 条评论
登录 后参与评论

相关文章

来自专栏北京马哥教育

一文说尽 MySQL 优化原理

2116
来自专栏java一日一条

你不得不知道的 MySQL 优化原理

说起MySQL的查询优化,相信大家收藏了一堆奇淫技巧:不能使用SELECT *、不使用NULL字段、合理创建索引、为字段选择合适的数据类型….. 你是否真的理解...

632
来自专栏Java Edge

操作系统之进程管理一、进程二、进程状态及状态转换三、进程队列四、进程控制五、深入理解六、线程七、死锁二、资源分配图(RAG:Resource Allocation Graph)三、死锁预防四、死锁避免

35110
来自专栏程序员宝库

我必须得告诉大家的 MySQL 优化原理

说起MySQL的查询优化,相信大家收藏了一堆奇技淫巧:不能使用SELECT *、不使用NULL字段、合理创建索引、为字段选择合适的数据类型….. 你是否真的理解...

1394
来自专栏python学习路

八、线程和进程 什么是线程(thread)?什么是进程(process)? 线程和进程的区别?Python GIL(Global Interpreter Lock)全局解释器锁

什么是线程(thread)? 线程是操作系统能够进行运算调度的最小单位。它被包含在进程之中,是进程中的实际运作单位。一条线程指的是进程中一个单一顺序的控制流,一...

3677
来自专栏蓝天

io_submit、io_setup和io_getevents示例

io_submit、io_setup和io_getevents是LINUX上的AIO系统调用。这有一个非常特别注意的地方——传递给io_setup的aio_co...

811
来自专栏吴生的专栏

MySQL Optimization 优化原理

如果能在头脑中构建一幅MySQL各组件之间如何协同工作的架构图,有助于深入理解MySQL服务器。下图展示了MySQL的逻辑架构图。

41415
来自专栏陈福荣的专栏

十问 Linux 虚拟内存管理 ( 一 )

最近在做 MySQL 版本升级时( 5.1->5.5 ) , 发现了 mysqld 疑似“内存泄露”现象,但通过 valgrind 等工具检测后,并没发现类似的...

5.6K1
来自专栏LuckQI

了解Spark中的RDD

1135
来自专栏LanceToBigData

MySQL优化原理

前言 说起MySQL的查询优化,相信大家收藏了一堆:不能使用SELECT *、不使用NULL字段、合理创建索引、为字段选择合适的数据类型..... 你是否真的理...

1939

扫码关注云+社区