我通过tcp读取高频数据,代码如下
while (1) {
lrev = recv(fd, buff, 80, MSG_WAITALL);
dowork();
}
我正在通过一个线程运行这段代码,并将这个线程分配给一个特定的 CPU 核心。我可以看到特定核心使用 100% CPU。是因为 while(1) 循环吗?延迟目的是好是坏?
我的进程有 5 个线程,每个线程都在单独的核心上运行。我的总 CPU 使用率约为 400%。
谢谢
最佳答案
- 我可以看到特定核心使用 100% CPU。是因为 while(1) 循环吗?
我们看不到您的所有代码,但是一段时间 (1) 处理非阻塞函数 通常会在其绑定(bind)的 CPU 上以 100% 的速度旋转
- 对于延迟目的来说是好是坏?
对于延迟非常敏感的系统,这通常是好的(如果你想最小化数据包到达网卡和你开始处理它之间的时间/延迟)
但是您的调用接收 MSG_WAITALL might block ,这对您的延迟不利
This flag requests that the operation block until the full request is satisfied.
判断它是好是坏的唯一明确答案是:测量所有场景中的延迟。
编辑:
正如@Captain Obvlious 所评论的,您必须检查recv
返回的值
关于c++ - TCP 接收使用率 100% CPU,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/23977053/