IO_SERVICE,为什么以及如何使用它?

io_service, why and how is it used?(IO_SERVICE,为什么以及如何使用它?)
本文介绍了IO_SERVICE,为什么以及如何使用它?的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

问题描述

正在尝试学习ASIO,我正在按照网站上的示例操作。

为什么需要io_service,它的具体用途是什么?为什么我在执行异步操作时需要将它发送到几乎所有其他函数,为什么它不能在第一个"绑定"之后"创建"自己。

推荐答案

ASIO的io_service是操作异步函数的促进器。一旦异步操作准备好,它就会使用io_service的一个运行线程来回调您。如果不存在这样的线程,它会使用自己的内部线程来调用您。

可以将其视为包含操作的队列。它保证这些操作在运行时将仅在调用其run()run_once()方法的线程上执行,或者在处理套接字和异步IO(其内部线程)时执行。

必须传递给每个人的原因基本上是有人必须等待异步操作准备好,而且正如它自己的文档io_service所述,是ASIO到操作系统的I/O服务的链接,所以它抽象了平台自己的异步通知器,比如<[2-5],/dev/pool/epoll,以及在这些通知上操作的方法,比如select()

我最终主要使用io_service对来自系统多个部分的回调进行多路分解,并确保它们在同一线程上操作,消除了显式锁定的需要,因为操作是序列化的。对于异步应用程序来说,这是一个非常强大的习惯用法。

您可以查看core documentation以更好地了解为什么需要io_service以及它的作用。

这篇关于IO_SERVICE,为什么以及如何使用它?的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持编程学习网!

本站部分内容来源互联网,如果有图片或者内容侵犯您的权益请联系我们删除!

相关文档推荐

socks4 with asynchronous boost::asio(带有异步Boost::ASIO的socks4)
Boost ASIO HTTP client POST(增强ASIO HTTP客户端开机自检)
asio::strandlt;asio::io_context::executor_typegt; vs io_context::strand(Asio::strandlt;asio::io_context::executor_typegt;VS io_CONTEXT::Strand)
What#39;s the difference between asio::io_context and asio::thread_pool?(ASIO::IO_CONTEXT和ASIO::THREAD_POOL有什么区别?)
How to use boost::asio with Linux GPIOs(如何在Linux GPIO中使用Boost::ASIO)
Boost asio io_service vs io_context(增强ASIO io_服务与io_Context)