- android - RelativeLayout 背景可绘制重叠内容
- android - 如何链接 cpufeatures lib 以获取 native android 库?
- java - OnItemClickListener 不起作用,但 OnLongItemClickListener 在自定义 ListView 中起作用
- java - Android 文件转字符串
我创建了 3 个线程,每个线程都有一个套接字。在每个线程中,套接字被设置为“事件驱动”,并且每当数据可供读取时,就会生成一个事件。
该代码工作正常,但它占用 CPU 使用率高达 100%,这肯定是不可取的。我想我犯了一些错误。下面是我的代码。请帮助我找出导致 100% CPU 使用率的错误。
代码:
DWORD WINAPI ThreadProc(LPVOID param)
{
int threadNumber= (int)param;
int PORT = 8888+threadNumber; //so that each thread bind()s its socket to a different Port number.
WSADATA wsa;
//Initialise winsock//
if (WSAStartup(MAKEWORD(2,2),&wsa) != 0)
{
//"WinSock Initialization FAILED",
}
//Create a socket//
SOCKET newSocketIdentifier;
SOCKADDR_IN newSocket;
if((newSocketIdentifier = socket(AF_INET , SOCK_DGRAM , 0 )) == INVALID_SOCKET)
{
//Socket Creation Failed
}
//Socket Created//
//Prepare the sockaddr_in structure//
newSocket.sin_family = AF_INET;
newSocket.sin_addr.s_addr = INADDR_ANY;
newSocket.sin_port = htons(PORT);
//Bind//
if( bind(newSocketIdentifier ,(struct sockaddr *)&newSocket, sizeof(SOCKADDR_IN)) == SOCKET_ERROR)
{
//Bind Failed
}
//Bind Done//
char data[256];
int bytes, waitRet;
WSAEVENT hEvent = WSACreateEvent();
WSANETWORKEVENTS events;
WSAEventSelect(newSocketIdentifier, hEvent, FD_READ | FD_WRITE);
while(1)
{
waitRet = WSAWaitForMultipleEvents(2, &hEvent, FALSE, WSA_INFINITE, FALSE);
if(WSAEnumNetworkEvents(newSocketIdentifier,hEvent,&events) == SOCKET_ERROR)
//Error
else
{
if(events.lNetworkEvents & FD_READ)
{
//call recvfrom()
}
}
}
WSACloseEvent(hEvent);
return 0;
}
int WINAPI WinMain( HINSTANCE hInst, HINSTANCE hPrevInstance, LPSTR lpCmdLine, int nShowCmd )
{
HANDLE threadHandle[3];
DWORD threadId = 0;
int max_number=3;
//Start the threads
for (int i = 0; i < max_number; i++)
{
threadHandle[i]= CreateThread( NULL,
0,
ThreadProc,
(LPVOID) i,
0,
NULL
);
}
return 0;
}
最佳答案
这是一个错误:
waitRet = WSAWaitForMultipleEvents(2, &hEvent, FALSE, WSA_INFINITE, FALSE);
因为它说明在提供的事件数组中有两个事件,实际情况并非如此,因为只有 1 个。来自 WSAWaitForMultipleEvents()
描述第一个参数的引用页:
The number of event object handles in the array pointed to by lphEvents. The maximum number of event object handles is WSA_MAXIMUM_WAIT_EVENTS. One or more events must be specified.
我怀疑这会导致未定义的行为,因为 WSAWaitForMultipleEvents()
正在访问数组的边界,可能导致函数无法阻塞,从而导致繁忙的循环。
此外,请参阅 Rohan 的回答关于 WSAResetEvent()
的使用。
关于创建 3 个线程并使用 WSAWaitForMultipleEvents() 和 WSAEnumNetworkEvents() 时 CPU 使用率 100%,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/16417837/
我正在使用 WSAWaitforMultipleEvents() 函数,我认为这使我的套接字成为非阻塞的,即 recvfrom() 仅在生成 FD_READ 事件并且套接字上有数据可供读取时才调用。所
我正在尝试通过 WSAWaitForMulipleObjects 获取 FD_CLOSE 事件 (c++)。在 WSASelectEvent 中我只设置了 FD_CLOSE。然而,等待返回,网络枚举也
APC(异步过程调用)能否中断 WSAWaitForMultipleEvents()? (C++) MSDN 没有在 APC 页面 (http://msdn.microsoft.com/en-us/l
我创建了 3 个线程,每个线程都有一个套接字。在每个线程中,套接字被设置为“事件驱动”,并且每当数据可供读取时,就会生成一个事件。 该代码工作正常,但它占用 CPU 使用率高达 100%,这肯定是不可
我是一名优秀的程序员,十分优秀!