草庐IT

signals-slots

全部标签

c++ - 理解 pthread_cond_wait() 和 pthread_cond_signal()

一般来说,pthread_cond_wait()和pthread_cond_signal()的调用方式如下://thread1:pthread_mutex_lock(&mutex);pthread_cond_wait(&cond,&mutex);do_something()pthread_mutex_unlock(&mutex);//thread2:pthread_mutex_lock(&mutex);pthread_cond_signal(&cond);pthread_mutex_unlock(&mutex);步骤是pthread_cond_wait(&cond,&mutex);被调

c++ - 使用 Boost::Signals 进行 C++ 事件的完整示例

我知道boost.org上的教程解决了这个问题:Boost.orgSignalsTutorial,但示例并不完整,而且有些过于简化。那里的示例没有显示包含文件,并且代码的某些部分有点模糊。这是我需要的:ClassA引发多个事件/信号ClassB订阅这些事件(可以订阅多个类)在我的项目中,我有一个较低级别的消息处理程序类,该类将事件引发到业务类,该业务类对这些消息进行一些处理并通知UI(wxFrames)。我需要知道这些都是如何连接起来的(什么顺序,谁调用谁,等等)。 最佳答案 下面的代码是您所要求的最小工作示例。ClassA发出两个

c++ - Qt "private slots:"这是什么?

我知道如何使用它,但它的语法让我很困扰。“私有(private)插槽:”是做什么的?我以前从未在类定义中看到private关键字和:之间有什么东西。这里有什么花哨的C++魔法吗?这里是例子:#includeclassCounter:publicQObject{Q_OBJECTpublic:Counter(){m_value=0;}intvalue()const{returnm_value;}publicslots:voidsetValue(intvalue);... 最佳答案 插槽是C++的Qt特定扩展。它仅在通过Qt的预处理器Me

c++ - 在不锁定互斥锁的情况下调用 pthread_cond_signal

我在某处读到我们应该在调用pthread_cond_signal之前锁定mutex并在调用之后解锁互斥锁:Thepthread_cond_signal()routineisusedtosignal(orwakeup)anotherthreadwhichiswaitingontheconditionvariable.Itshouldbecalledaftermutexislocked,andmustunlockmutexinorderforpthread_cond_wait()routinetocomplete.我的问题是:在不锁定互斥体的情况下调用pthread_cond_signal

c++ - 为什么 <signal.h> 会阻止使用 "si_"作为某些变量名称的前缀?

我一直在调试我的代码中出现的一个奇怪的编译错误,最后我发现我不能使用前缀si_如果用于某些变量名称(任何类型)包括在内。这是一个重现问题的非常简单的源代码示例:#includeintmain(void){intsi_value=0;return0;}如果我尝试使用GNUC编译器来编译它gcc,我收到以下错误:>gccexample.cInfileincludedfrom/usr/include/signal.h:57:0,fromexample.c:2:example.c:Infunction‘main’:example.c:6:9:error:expected‘=’,‘,’,‘;’,

c++ - 为什么 <signal.h> 会阻止使用 "si_"作为某些变量名称的前缀?

我一直在调试我的代码中出现的一个奇怪的编译错误,最后我发现我不能使用前缀si_如果用于某些变量名称(任何类型)包括在内。这是一个重现问题的非常简单的源代码示例:#includeintmain(void){intsi_value=0;return0;}如果我尝试使用GNUC编译器来编译它gcc,我收到以下错误:>gccexample.cInfileincludedfrom/usr/include/signal.h:57:0,fromexample.c:2:example.c:Infunction‘main’:example.c:6:9:error:expected‘=’,‘,’,‘;’,

c++ - 在 Qt 中发送信号时的 const-ref

这是我在const-ref中从未完全理解过的事情,我真的希望有人可以向我解释。当在另一个函数内部调用一个函数时,我知道const-ref是传递我不打算篡改的堆栈对象时的最佳方式。例如:voidsomeInnerFunction(constQString&text){qDebug()到目前为止一切都很好,我猜。但是信号呢?传递引用是否有任何风险?即使它是const。感觉就像我一直在阅读有关const-ref的所有文档,但我仍然觉得有点冒险,因为我将其理解为“发送对对象的引用并保留它const”。如果它所指的对象超出范围怎么办?例如:voidsomeFunction(){connect(t

c++ - 在 Qt 中发送信号时的 const-ref

这是我在const-ref中从未完全理解过的事情,我真的希望有人可以向我解释。当在另一个函数内部调用一个函数时,我知道const-ref是传递我不打算篡改的堆栈对象时的最佳方式。例如:voidsomeInnerFunction(constQString&text){qDebug()到目前为止一切都很好,我猜。但是信号呢?传递引用是否有任何风险?即使它是const。感觉就像我一直在阅读有关const-ref的所有文档,但我仍然觉得有点冒险,因为我将其理解为“发送对对象的引用并保留它const”。如果它所指的对象超出范围怎么办?例如:voidsomeFunction(){connect(t

Ruby Signal Trapper 优先级

在Ruby中,我很清楚最近注册的信号捕获器具有优先权,因此:Signal.trap("TERM"){puts"foo";exit}Signal.trap("TERM"){puts"bar";exit}如果我向上面的脚本发出“kill”命令,它会打印出“bar”并退出。有没有办法在Ruby本身中为trappers强制执行某种范围?我的具体情况是这样的:我们有一个应用程序在命名空间信号模块中定义了自己的捕获器(对于这个故事,我们只说它只捕获“TERM”)。该代码在运行时需要添加到应用程序中,之后几乎不用管。我们使用的第3方gem(我不会说出名字)实际上在初始化方法中为“TERM”注册了自己

c++ - Qt:槽返回值的含义?

根据文档,插槽的返回值没有任何意义。然而,在生成的moc代码中,我看到如果一个插槽返回一个值,则该值用于某事。知道它有什么作用吗?这是我所说的一个例子。这取自moc生成的代码。'message'是一个不返回任何内容的插槽,'selectPart'被声明为返回int。case7:message((*reinterpret_cast(_a[1])),(*reinterpret_cast(_a[2])));break;case8:{int_r=selectPart((*reinterpret_cast(_a[1])),(*reinterpret_cast(_a[2])));if(_a[0])