multithreading - 从信号处理程序访问共享数据

标签 multithreading pthreads multiprocessing semaphore

我想知道从信号处理程序访问共享数据是否是个好主意。我的意思是考虑多进程系统和单进程多线程系统的场景。在多进程系统中,假设我让进程处理特定信号并由进程更新某些共享变量或内存。我可以从信号处理程序本身做到这一点。

但是,在线程使用 pthreads 的情况下,我认为这是不可行的。 http://maxim.int.ru/bookshelf/PthreadsProgram/htm/r_40.html .如本文所述,他们提到它不是异步信号安全的,并建议为此使用 sigwait。我不是为什么它不是异步信号安全的。我的意思是说,我通过线程处理信号并且处于信号处理程序路由中。我获取了共享内存的锁来更新它。与此同时,另一个相同类型的信号到达,另一个负责处理它的线程再次执行信号处理程序。这里的信号处理程序对于进程来说是相同的,但它被多次调用。第二次,它看不到锁并更新/覆盖数据。这是使用共享数据的多线程信号处理程序的问题吗?

我有点困惑,在多进程系统中,我有每个进程的信号处理程序的副本。但是在多线程系统中,多个线程使用的信号处理程序只有一个副本,不是吗。那么当多个相同类型的信号到达并且我们有两个负责处理它的线程尝试处理它时,那么它们都会尝试执行同一段处理程序代码吗?这一切是如何适应的?

最佳答案

我通读了您引用的文章,并在 中找到了一些有趣的信息。 “信号处理程序中的线程”部分。在该部分中,您将看到它们有一个 Posix 函数调用列表,这些调用可以在信号处理程序中进行。然后在该列表之后不久,他们提到了以下内容:

But where are the Pthreads calls? They're not in either of these lists! In fact, the Pthreads standard specifies that the behavior of all Pthreads functions is undefined when the function is called from a signal handler. If your handler needs to manipulate data that is shared with other threads≈buffers, flags, or state variables≈it's out of luck. The Pthreads mutex and condition variable synchronization calls are off limits.



注意最后一句:“Pthreads mutex 和条件变量同步调用是禁止的”

可以从信号处理程序调用的上述函数描述如下:

These functions have a special property known as reentrancy that allows a process to have multiple calls to these functions in progress at the same time.



pthread 同步函数没有称为可重入性的特殊属性,所以我想如果这些函数(例如 pthread_mutex_lock())被到达的信号中断,那么这种行为就不是“安全的”。

假设您的应用程序调用 pthread_mutex_lock(&theMutex)就在那个时刻(即在 pthread_mutex_lock() 函数中)一个信号到达。如果信号处理程序也调用 pthread_mutex_lock(&theMutex) ,之前的 pthread 调用可能没有终止,因此无法保证对 pthread_mutex_lock() 的哪个调用会获得锁。因此,由此产生的行为将是不确定的/不确定的。

我想从特定线程调用 sigwait() 将保证不重要,non-reentrancy函数调用可能会被中断,因此对 pthread 同步函数的调用是“安全的”。

关于multithreading - 从信号处理程序访问共享数据,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/12445618/

相关文章:

c - 以非常低的优先级运行线程

c - 多线程程序中段错误的原因

python - 多处理与 NumPy 不兼容

multithreading - 如何从 Try 同时创建 Future?

java - 在不使用 Callable 的情况下从线程引发异常?

c# - 为什么 SynchronizationContext.Current 为空?

python-3.x - 如何在 Python 3 中使用具有多个参数的多处理?

python - Python 中的多处理与线程

c++ - 为什么 pthread_join 给出这个错误? [错误] 从 'void*' 到 'void**' 的无效转换 [-fpermissive]

python - 如何使用线程/多处理来防止程序挂起?