gpt4 book ai didi

c++ - 使用事件同步线程

转载 作者:行者123 更新时间:2023-11-28 08:08:55 40 4
gpt4 key购买 nike

这是我第一次使用事件同步线程。我的代码工作正常。但据我所知,它看起来不错,但有明显的错误,当我在更大的项目中使用这个概念时,很难找到。

所以我只想问一下这种使用事件同步线程的方式是否适合您?

我们的想法是我们有只能从主线程调用的 GetSymbol 函数。服务器线程需要向主线程询问此函数的结果。

#include <windows.h>
#include <process.h>
#include <stdio.h>

HANDLE symbol_need, symbol_ready, end;

int symbol_container;

int GetSymbol()
{
// Only main thread can use this function.
static int i = 0;
return ++i;
}

void Server(void* p)
{
printf("Ask for first symbol.\n");
SetEvent(symbol_need);

DWORD wait_result;

wait_result = WaitForSingleObject(symbol_ready, INFINITE);
if(WAIT_OBJECT_0 == wait_result)
{
ResetEvent(symbol_ready);
printf("First symbol: %i\n", symbol_container);
} else {
printf("Something went wrong.\n");
}

printf("Ask for second symbol.\n");
SetEvent(symbol_need);

wait_result = WaitForSingleObject(symbol_ready, INFINITE);
if(WAIT_OBJECT_0 == wait_result)
{
ResetEvent(symbol_ready);
printf("Second symbol: %i\n", symbol_container);
} else {
printf("Something went wrong.\n");
}

printf("OK, finish it.");
SetEvent(end);
}


int main(int argc, char* argv[])
{
symbol_need = CreateEvent( NULL, FALSE, FALSE, NULL );
symbol_ready = CreateEvent( NULL, FALSE, FALSE, NULL );
end = CreateEvent( NULL, FALSE, FALSE, NULL );

_beginthread(Server, 0, NULL);

DWORD wait_result;

while(1)
{
wait_result = WaitForSingleObject(symbol_need, 100);
if(WAIT_OBJECT_0 == wait_result)
{
ResetEvent(symbol_need);
symbol_container = GetSymbol();
SetEvent(symbol_ready);
}
wait_result = WaitForSingleObject(end, 100);
if(WAIT_OBJECT_0 == wait_result)
{
break;
}
}
return 0;
}

最佳答案

是的,这段代码是正确的。

此示例有助于了解事件的工作原理。但是,编写生产代码时无需重新发明轮子。例如,您描述的交互可以使用并发数据结构(如英特尔 TBB 库中的数据结构)进行优雅建模,例如concurrent_bounded_queue .

关于c++ - 使用事件同步线程,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/9575089/

40 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com