高精度/微秒级线程的实现

本文介绍了如何在C++中实现微秒级的线程轮询,详细探讨了普通线程轮询的限制,并通过提高线程优先级、避免休眠和绑定CPU核心等手段,实现了100微秒的精准间隔。虽然这种方法可能导致资源浪费,但在特定需求下,提供了一种解决思路。
摘要由CSDN通过智能技术生成

前言

在项目中需要实现一个功能,来对项目做一些特殊的工作.这个工作中需要实现某个线程中按照特定间隔(100微秒~10毫秒)来定时执行.实现过程中发现只要使用执行休眠的函数(sleep,sleep_for,sleep_until)每次线程轮询的时间都必定大于1.5毫秒(不同主频的CPU,可能时间会有一些差别),为了满足需求,使用一些方法来达到这个目的.

普通线程轮询

使用std::thread创建线程,使用std::chrono来处理时间.
创建一个线程,然后在线程当中运行,我们可以发现,线程轮询间隔大概是1500毫秒~2000毫秒.
代码如下(统计1001次,取平均值,并且已消除cout打印的时间影响)

#include "stdafx.h"
#include <windows.h>
#include <thread>
#include <iostream>
using namespace std;
using namespace std::chrono;
#define INTERVAL_ARRAY_LENGTH                1000 + 1 //第一个数据不使用
void thread_function_1() {
    high_resolution_clock::time_point time_point_start, time_point_end;
    uint64_t interval_in_microsecond, interval_array[INTERVAL_ARRAY_LENGTH] = {}, interval_array_index = 0;
    uint64_t total, average;
    cout << __FUNCTION__ << endl;
    while (1) {
        time_point_start = high_resolution_clock::now();
        std::this_thread::sleep_for(std::chrono::milliseconds(1));//这里替换成Sleep(1)效果也是一样的.
        time_point_end = high_resolution_clock::now();
        interval_in_microsecond = duration_cast<chrono::microseconds>(time_point_end - time_point_start).count();
        interval_array[interval_array_index++] = interval_in_microsecond;
        //当收集完数据后,对数据做一次统计和打印.
        if (interval_array_index == INTERVAL_ARRAY_LENGTH) {
            interval_array_index = 0;
            total = 0;
            for (int i = 1; i < INTERVAL_ARRAY_LENGTH; i++) {
                total += interval_array[i];
            }
            average = total / (INTERVAL_ARRAY_LENGTH - 1);
            std::cout << "thread[1] average:" << average << ",interval_array[0]=" << interval_array[0] << std::flush << std::endl;
        }
    }
}
int main()
{
    std::thread thread_1(thread_function_1);
    system("pause");
    return 0;
}

结果如下

  • 4
    点赞
  • 23
    收藏
    觉得还不错? 一键收藏
  • 3
    评论
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值