基于c++11设计一个定时器timer

本文介绍如何利用C++11特性设计一个跨平台的异步定时器。传统的Windows定时器基于消息队列,而C++11提供了标准函数和类,使得实现一个同步定时器成为可能。提供的示例代码展示了一个简单但功能完整的定时器实现。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

这里设计了一个异步定时器,在windows下定时器通常是基于消息队列实现的,也是同步的。c++11提供了一系列方便我写一个跨平台定时器的标准函数和类。以下是一个简单的但是完备的定时器的实现。


#pragma once
#include <limits>
#include <condition_variable>    // std::condition_variable
#include <chrono>
#include <thread>
#include <mutex>
#include <memory>
#include <functional>
#include <atomic>
#include "min_max_heap.hpp"//仿照消息队列queue,添加了几个函数,他是最小堆。代码就不上传了
#if defined(_WIN32)
#define TRACE(...)  _CrtDbgReport( _CRT_WARN, __FILE__, __LINE__, "min_max_heap",__VA_ARGS__  );
#else
#define TRACE(...) printf(__VA_ARGS__);
#endif
namespace prudens
{
    uint64_t now()
    {
        return duration_cast<milliseconds>(
            system_clock::now() - time_point<system_clock>() ).count();
    }
    typedef  std::function<void( uint32_t, void* ) > timer_callback;
    struct timer_msg
    {
#define MAX_MACRO_COMPILE_SUPPORT
        uint32_t timer_id;
        uint32_t elapsed;
        uint64_t expired;
        bool repeat;
        void* userdata;
        timer_callback action;
        timer_msg() :timer_id( 0 ),
            elapsed( 0 ),
            expired( std::numeric_limits<uint64_t>::max MAX_MACRO_COMPILE_SUPPORT() ),
            repeat( false ),
            userdata(
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值