本文整理汇总了C++中Signal::emitSignal方法的典型用法代码示例。如果您正苦于以下问题:C++ Signal::emitSignal方法的具体用法?C++ Signal::emitSignal怎么用?C++ Signal::emitSignal使用的例子?那么, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在类Signal
的用法示例。
在下文中一共展示了Signal::emitSignal方法的2个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C++代码示例。
示例1:
TEST_F(SignalTest, MemberFunction) {
TestClass tc;
Signal<int> testSignal;
testSignal.connectMemberSlot(ExecutorScheme::SYNCHRONOUS, &TestClass::dostuff, tc);
testSignal.connectMemberSlot(ExecutorScheme::SYNCHRONOUS, &TestClass::dostuffconst, tc);
testSignal.emitSignal(1);
ASSERT_EQ(tc.getCounter(), 2u);
tc.emitIncrement();
ASSERT_EQ(tc.getCounter(), 3u);
testSignal.connectMemberSlot(ExecutorScheme::SYNCHRONOUS, &TestClass::dostuff, &tc);
testSignal.emitSignal(1);
ASSERT_EQ(tc.getCounter(), 6u);
Signal<int> testSignal2;
testSignal2.connectMemberSlot(ExecutorScheme::SYNCHRONOUS, &TestClass::dostuffconst, tc);
testSignal2.emitSignal(1);
ASSERT_EQ(tc.getCounter(), 7u);
const TestClass tc2;
testSignal2.connectMemberSlot(ExecutorScheme::SYNCHRONOUS, &TestClass::dostuffconst, tc2);
testSignal2.connectMemberSlot(ExecutorScheme::SYNCHRONOUS, &TestClass::dostuffconst, &tc2);
testSignal2.emitSignal(1);
ASSERT_EQ(tc2.getCounter(), 2u);
}
示例2: while
TEST_F(SignalTest, MultiEmit){
cout << "Instantiating signal object" << endl;
Signal<int, int> testSignal;
BasicTimer bt;
BasicTimer bt2;
cout << "Connecting signal" << endl;
bt.start();
int id = testSignal.connectSlot(ExecutorScheme::STRAND, staticSumFunction);
bt.stop();
cout << "Time to connect: " << bt.getElapsedMilliseconds() << "ms" << endl;
cout << "Emitting signal" << endl;
bt.start();
list<thread> threads;
const uint32_t nThreads = 64;
std::atomic<uint32_t> threadsRemaining{nThreads};
for (uint32_t i=0; i<nThreads; i++){
threads.emplace_back([&, i](){
for (uint32_t i=0; i<1000000; ++i){
testSignal.emitSignal(1, 2);
}
uint32_t tr = threadsRemaining.fetch_sub(1);
cout << "Threads remaining: " << tr-1 << endl;
cout << "globalStaticInt: " << globalStaticIntX << endl;
});
}
bt.stop();
bt2.start();
while (bt2.getElapsedSeconds() < 60.0) {
if (globalStaticIntX == 1000000*3*nThreads) {
bt2.stop();
break;
}
std::this_thread::sleep_for(std::chrono::milliseconds(100));
}
//ASSERT_LT(bt2.getElapsedSeconds(), 0.1);
cout << "Time to emit: " << bt.getElapsedMilliseconds() << "ms" << endl;
cout << "Time to emit and process: " << bt2.getElapsedMilliseconds() << "ms" << endl;
cout << "Net time to process: " << bt2.getElapsedMilliseconds() - bt.getElapsedMilliseconds() << "ms" << endl;
ASSERT_EQ(0, id);
testSignal.disconnectAllSlots();
for (auto &t : threads) t.join();
}