c++ 实现延迟方法

参考c++中实现sleep的三种方式(跨平台)_鸟哥01的博客-CSDN博客_c++ sleep

C++ yield()与sleep_for() - yepanl的个人空间 - OSCHINA - 中文开源技术交流社区

1、stl方式
    std::this_thread::sleep_for(std::chrono::milliseconds(3000));

或std::this_thread::sleep_for(std::chrono::seconds(3));

(1)std::this_thread::yield (): 线程调用该方法时,主动让出 CPU,并且不参与 CPU 的本次调度,从而让其他线程有机会运行。在后续的调度周期里再参与 CPU 调度。这是主动放弃 CPU 的方法接口。

    (2)std::sleep_for ():线程调用该方法时,同样会让出 CPU,并且休眠一段时间,从而让其他线程有机会运行。等到休眠结束时,才参与 CPU 调度。这也是主动放弃 CPU 的方法。

    两者的不同很明显,yield () 方法让出 CPU 的时间是不确定的,并且以 CPU 调度时间片为单位。而 sleep_for () 让出 CPU 的时间是固定的。

    yield () 的实现依赖于操作系统 CPU 调度策略,在不同的操作系统或者同一个操作系统的不同调度策略下,表现也可能是不同的。

2、用boost实现, 没有用过

boost::this_thread::sleep( boost::posix_time::seconds(3) );

boost::this_thread::sleep( boost::posix_time::milliseconds(3000) );

3、

#ifdef _WIN32

#include <windows.h>

#else

#include <unistd.h>

#endif // _WIN32

void sleepcp(int milliseconds) // 跨平台 sleep 函数
{
    #ifdef _WIN32
        Sleep(milliseconds);//释放cp
    #else
        usleep(milliseconds * 1000);
    #endif // _WIN32
}
 

  • 0
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 2
    评论
以下是一个简单的 C++ Kafka 延迟消费消息的示例代码: ```c++ #include <iostream> #include <librdkafka/rdkafkacpp.h> int main() { std::string brokers = "localhost:9092"; std::string topic = "test_topic"; std::string group_id = "test_group"; RdKafka::Conf *conf = RdKafka::Conf::create(RdKafka::Conf::CONF_GLOBAL); std::string errstr; // 设置 Kafka brokers if (conf->set("bootstrap.servers", brokers, errstr) != RdKafka::Conf::CONF_OK) { std::cerr << "Failed to set brokers: " << errstr << std::endl; return 1; } // 设置消费者组 if (conf->set("group.id", group_id, errstr) != RdKafka::Conf::CONF_OK) { std::cerr << "Failed to set group id: " << errstr << std::endl; return 1; } // 设置消费者自动提交偏移量 if (conf->set("enable.auto.commit", "true", errstr) != RdKafka::Conf::CONF_OK) { std::cerr << "Failed to set auto commit: " << errstr << std::endl; return 1; } // 创建消费者对象 RdKafka::KafkaConsumer *consumer = RdKafka::KafkaConsumer::create(conf, errstr); if (!consumer) { std::cerr << "Failed to create consumer: " << errstr << std::endl; return 1; } // 订阅主题 std::vector<std::string> topics = {topic}; if (consumer->subscribe(topics, errstr) != RdKafka::ERR_NO_ERROR) { std::cerr << "Failed to subscribe to topic " << topic << ": " << errstr << std::endl; return 1; } while (true) { // 从 Kafka 获取消息 RdKafka::Message *msg = consumer->consume(1000); if (!msg) { continue; } // 检查消息是否有效 if (msg->err() != RdKafka::ERR_NO_ERROR) { std::cerr << "Failed to consume message: " << msg->errstr() << std::endl; continue; } // 在这里添加延迟逻辑 std::cout << "Received message: " << std::string((char *)msg->payload()) << std::endl; // 手动提交偏移量 consumer->commitSync(msg); } return 0; } ``` 在上面的代码中,我们首先创建了一个 Kafka 消费者对象,并设置了 Kafka brokers、消费者组、自动提交偏移量等参数。然后我们订阅了一个主题,并在一个循环中持续从 Kafka 获取消息。在获取到消息后,我们可以在这里添加延迟逻辑,比如等待一段时间再处理消息。最后,我们手动提交偏移量,以确保消息不会被重复消费。 需要注意的是,上面的代码只是一个简单的示例,实际使用中还需要考虑更多的因素,比如异常处理、多线程处理等。同时,延迟消费消息也可能会对系统的实时性产生影响,需要根据实际需求进行权衡。
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

woquNOKIA

谢谢老板!

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值