我正在编写的代码有很多调用来创建新的字符串之类的东西。但最近在将服务器升级到12.10 Ubuntu后,我开始遇到一些麻烦。一些子进程会卡在futex中。因此,我将GDB附加到在futex中运行了很长一段时间的进程,我执行了一个backtrace,并找到了以下日志
#0 0x00007f563afc69bb in ?? () from /lib/x86_64-linux-gnu/libc.so.6
#1 0x00007f563af4a221 in ?? () from /lib/x86_64-linux-gnu/libc.so.6
#2 0x00007f563af47fa7 in mal
我对Linux API sem_unlink()有点困惑,主要是在什么时候或为什么调用它。我在Windows中使用信号量已经很多年了。在Windows中,一旦关闭了命名信号量的最后一个句柄,系统就会删除底层内核对象。但是在Linux中,开发人员需要通过调用sem_unlink()来删除内核对象。如果不这样做,内核对象将保留在/dev/shm文件夹中。
我遇到的问题是,如果进程A调用sem_unlink(),而进程B锁定了信号量,它会立即销毁信号量,现在当进程C出现时,进程B不再受信号量的“保护”。更重要的是,手册页充其量也是令人困惑的:
“信号量名称将立即删除。一旦打开信号量的所有其他进程将其
根据甲骨文的,在信号处理程序内部使用fork()应该是安全的.但是我的进程被卡在信号处理程序中,并跟踪跟踪:
#0 __lll_lock_wait_private () at ../nptl/sysdeps/unix/sysv/linux/x86_64/lowlevellock.S:95
#1 0x00007f86e6a9990d in _L_lock_48 () from /lib/x86_64-linux- gnu/libc.so.6
#2 0x00007f86e6a922ec in ptmalloc_lock_all () at arena.c:242
#3 0x00
我在TaskGenJob.h中有我的类,其中TaskGenModel继承自QObject:
TaskGenJob.h
class TaskGenJob : public TaskGenModel
{
Q_OBJECT
public:
TaskGenJob();
~TaskGenJob();
}
TaskGenJob::TaskGenJob()
{
//Connect signal itemExpanded to updateValue so that Display is updated only on tree expansi