草庐IT

asio_handler_invoke

全部标签

c++ - 如何读取 Boost ASIO streambuf?

有没有办法在不删除字节的情况下从streambuf中读取?我正在从缓冲区读取“消息大小”字段以检查是否收到了整条消息。如果不是,我将发布另一个异步读取以获取它,但处理程序无法知道消息应该有多长-因为大小字段已被删除。感谢任何帮助!例如boost::asio::streambuf_buffer;voidonReceive(constboost::system::error_code&e,std::size_tbytesTransferred){if(e)return;if(_buffer.size()>0){//Partialmessagewaspreviouslyreceived,bu

c++ - Boost Asio - 使用 shared_ptr 处理解析器和套接字

我有一个类能够通过TCP发送消息。这里是简化的界面:classCommandScreenshot:publicCameraCommand{public:CommandScreenshot();~CommandScreenshot();voidDispatch(boost::shared_ptrio_service);private:voidresolve_handler(constboost::system::error_code&err,boost::asio::ip::tcp::resolver::iteratorendpoint_iterator);};如您所见,我有一个函数Di

c++ - boost-asio 错误消息使用的编码是什么?

我正在使用boost-asio,我想正确处理错误消息。在这个例子中,我打错了字(1278而不是127):boost::system::error_codeec;autoaddress=boost::asio::ip::address::from_string("1278.0.0.1",ec);if(ec){autotext=ec.message();//DoSomethingwithtextbutwhatisitsencoding?}我收到一条错误消息,它似乎是在Windows1252中编码的(我使用的是Windows7)。所以看起来编码是操作系统编码。但是,我找不到任何说明这一事实的

c++ - Boost ASIO - 获取排序的端点(首先是 IPv4,然后是 IPv6)

当boostasio(1.42)获取端点时,它可能同时包含IPv4和IPv6。是否可以对端点进行排序(先是v4,然后是v6)?boost::asio::ip::tcp::resolverresolver(io_service);boost::asio::ip::tcp::resolver::queryquery(host,boost::lexical_cast(port));boost::asio::ip::tcp::resolver::iteratorendpoint_iterator=resolver.resolve(query);boost::asio::ip::tcp::res

c++ - 如何使用 lambda 来 boost asio 异步完成处理程序

#include#include#include#includevoidprint(boost::asio::deadline_timer*t,int*count){if(*countexpires_at(t->expires_at()+boost::posix_time::seconds(1));t->async_wait(boost::bind(print,t,count));}}intmain(){boost::asio::io_serviceio;intcount=0;boost::asio::deadline_timert(io,boost::posix_time::seco

c++ - 无法使 boost::asio 简单同步服务器教程程序正常工作——连接被拒绝

我正在关注套接字简介boost::asio教程here,称为同步TCP日间客户端。我已经准确地复制了代码,但随后将它们移到了Server.cpp和Client.cpp中。服务器.cpp#include#include#include#includeusingboost::asio::ip::tcp;std::stringmake_daytime_string(){std::time_tnow=time(0);returnctime(&now);}intmain(){try{std::cout客户端.cpp#include#includeusingboost::asio::ip::tcp

c++ - Boost asio TCP 异步服务器不异步?

我正在使用Boostexample中提供的代码.服务器一次只接受1个连接。这意味着,在当前连接关闭之前不会有新连接。如何让上面的代码同时接受无限制的连接?#include#include#include#include#includeusingboost::asio::ip::tcp;classsession:publicstd::enable_shared_from_this{public:session(tcp::socketsocket):socket_(std::move(socket)){}voidstart(){do_read();}private:voiddo_read(

c++ - boost::asio::ssl::context 可以在多个 SSL 流之间共享吗?

在互联网上搜索了几个小时,我找不到问题的答案。我的模型是这样的:我有一个共享的boost::asio::ssl::context用于创建boost::asio::ssl::stream的实例。然后将流对象传递给不同的线程。这个模型线程安全吗?可以使用相同的boost::asio::ssl::context构建将同时使用的不同SSL流对象吗?请,在将此问题标记为重复之前,请考虑仔细阅读说明。谢谢!在我的具体情况下,线程之间不共享任何对象。所以在Boost.AsioSSLthreadsafety中说了什么线程安全不影响我的情况。我从单个线程访问boost::asio::ssl::conte

c++ - 修改后的 std::invoke/std::apply,将可调用对象作为 void* - 可能吗?

在C++17中我们有std::invoke:templatestd::result_of_tinvoke(F&&f,ArgTypes&&...args);(并且在C++11中已经有std::experimental::apply,它是相似的,但有一个元组)。现在,我要实现:templateTinvoke(void*f,ArgTypes&&...args);与std::invoke的不同之处在于f是通过void指针传递的,并且其类型没有模板参数。然而,类型可以被人类读者推断出来,前提是f是一个指向普通独立函数的指针,我可以这样做:templateTmy_invoke(void*f,Arg

c++ - boost ASIO 和线程之间的消息传递

我正在设计一个websocket服务器,它接收一条消息并将其保存到一个嵌入式数据库。为了阅读消息,我正在使用boostasio.要将消息保存到嵌入式数据库,我会看到几个选项:在同一线程上收到消息后,立即同步保存消息。在单独的线程上异步保存消息。我很确定第二个答案是我想要的。但是,我不确定如何将消息从套接字线程传递到IO线程。我看到以下选项:每个线程使用一个io服务并使用postfunction线程之间进行通信。这里不得不担心锁的争用。我应该吗?使用Linux域套接字在线程之间传递消息。据我了解,没有锁争用。在这里,我可能可以使用BOOST_ASIO_DISABLE_THREADS宏来获