线程同步(四)—— 信号

这篇是进程线程的博文的最后一篇了,至此进程线程的所有同步内容已经全部回顾完了。 其中信号和信号量看起来名字很像,实际上却是完全不一样的两个东西,信号和信号量在进程线程中都可以使用。而且使用方式也基本完全一样。 进程中的共享内存,线程中的互斥锁,条件变量。这些是独有的,但实际也能互相使用,《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 条评论
登录 后参与评论

相关文章

来自专栏武军超python专栏

2018年8月25日多线程编程总结

PYTHON 本身也支持多任务处理,并且提供了如下的操作方式 多线程多任务处理机制   (比较常用) 多进程多任务处理机制   (不常用,大型项目开发或者系...

984
来自专栏木木玲

设计模式 ——— 职责链模式

1383
来自专栏小筱月

shell 文本操作命令

:s/old/new/g 将当前行中查找到的所有字符串“old” 替换为“new”

972
来自专栏自动化测试实战

推荐一个正则表达式软件——Match Tracer

1544
来自专栏流媒体

dll生成和使用

942
来自专栏我爱编程

Day15进程和线程

多进程 multiprocessing multiprocessing模块提供了一个Process类来代表一个进程对象,下面的例子演示了启动一个子进程并等待其结...

2815
来自专栏PPV课数据科学社区

python多线程编程(3): 使用互斥锁同步线程

问题的提出 上一节的例子中,每个线程互相独立,相互之间没有任何关系。现在假设这样一个例子:有一个全局的计数num,每个线程获取这个全局的计数,根据num进行一些...

2907
来自专栏Petrichor的专栏

AttributeError: 'module' object has no attribute 'fullmatch'.

经过查找,发现出错的原因是 re库 中的 fullmatch函数 是 在py3.4之后才新添加的 。

2263
来自专栏Core Net

ASP.NET Core 2.0 : 七.一张图看透启动背后的秘密

3555
来自专栏C/C++基础

C++覆盖或删除指定位置的文件内容

我们经常使用ofstream或者fstream可写文件,使用ifstream可以写文件,但需要设置文件的打开状态为ios::out。C++中IO流打开模式使用位...

1123

扫码关注云+社区