草庐IT

boost-uuid

全部标签

c++ - 在 async_read 处理程序在服务器中返回错误后调用 boost::asio::tcp::socket 方法

对于日志输出,我正在调用tcp::socket::remote_endpoint()来自shared_ptrSessionSession时的对象创建和销毁的时间。如果async_read被调用并且客户端在服务器发送回复之前发送了一个FIN,然后在服务器发送回复之后发送了一个RST数据包(write不返回任何错误),async_read函数返回错误代码system::54(not_connected-带有“连接由对等方重置”的消息),然后当我再次调用remote_endpoint方法时(在Session对象析构函数中)它抛出异常:libc++abi.dylib:terminatingwi

c++ - boost asio tcp 线程化。等待新 sample ?

我有一个使用boostasio将结构作为序列化数据发送的应用程序。一切正常,但我认为我运行效率低下。我发送的实际数据仅每30毫秒左右更新一次,但在发送和接收功能上,我正在运行一个不到1毫秒的循环。这意味着我多次发送相同的数据。我的问题是:我怎样才能使这种方法更有效?我可以轻松地在发送函数中添加一个condition_wait来等待新样本,但是是否可以让接收方等待新的已发送样本?发送函数是:voidConnection(){staticautoconstflags=boost::archive::no_header|boost::archive::no_tracking;while(tr

boost tcp 客户端有时无法检测到与服务器的断开连接

我正在使用boost::asio::tcp::socket连接到服务器,然后调用read_some()从Server接收二进制数据,代码如下:len=sock->read_some(boost::asio::buffer(pBuf),error);if(error==boost::asio::error::eof){break;}elseif(error){break;}但是在Server关闭socket之后,client仍然阻塞在read_some方法中,无法检测到与server的断开并得到错误信息。为什么会出现这个问题? 最佳答案

c++ - boost io_service 初始化 SIGSEGV

我正在编写一个smpp客户端,但遇到一个我无法解决的问题。我写了一个tcp_client类和一个内部io_service类来封装所有的tcp通信过程。之后我意识到我需要继承类中的控件来运行另一个要完成的任务,因此,我修改了tcp_client以在继承类的构造函数中初始化io_service,然后从那里post.tcp_client类:classtcp_client{public:tcp_client(boost::asio::io_service&_io_service,tcp::resolver::iteratorendpoint_iterator):m_io_service(_io

c++ - Boost::asio TCP 服务器——从客户端读取消息

我正在尝试使用boost::asio创建我的第一个TCP服务器。服务器将监听客户端,如果它收到消息“MESSAGE_SEND_A:”,它应该将以下消息发送回客户端:“A|A|A|A|A|A”。如果它收到消息“MESSAGE_SEND_B:”,那么它应该相应地向客户端发送另一条消息:“B|B|B|B|B|B”。现在,我一直在研究BoostTCP服务器教程,它或多或少是清晰的:编辑:代码根据评论重写#include#include#include#include#include#include#includeusingboost::asio::ip::tcp;classtcp_connec

c++ - boost asio tcp 异步读/写

我对boostasio如何处理这个有一个理解问题:当我在客户端查看我的请求响应时,我可以使用以下boost示例Example但我不明白如果服务器每隔X毫秒向客户端发送一些状态信息会发生什么。我是否为此打开了一个serperate套接字,或者我的客户端是否可以区分请求、响应和cycleMessage?客户端发送请求并读取为cycleMessage会发生吗?因为他也在因为这个Message等待async_read?classTcpConnectionServer:publicboost::enable_shared_from_this{public:typedefboost::shared

c++ - 修改 boost::asio::socket::set_option

我需要设置选项boost::asio::ip::tcp::no_delay和boost::asio::socket_base::lingerboost::asio::ip::tcp::socket连接到远程TCP服务器。我使用方法set_option来毫无问题地实现这一目标。问题:一旦io_servicerun()ing并且socket打开,如果我被要求更改它的选项(即:由于程序配置的更改),我可以在打开套接字的情况下进行吗?我需要在更改选项之前关闭它吗?如果我不关闭它,它会在我脸上爆炸吗?这方面的最佳做法是什么?我无法在文档中找到与此相关的任何信息。提前谢谢你。

c++ - 连接后连接丢失 -> 服务器 TCP boost.ASIO

我做了boost教程:异步TCP日间服务器http://think-async.com/Asio/asio-1.1.1/doc/asio/tutorial/tutdaytime3.html当我想测试它时,服务器正在运行,这很好,但如果我执行nc-Clocalhost4242,客户端会收到服务器的消息,但之后客户端会直接断开连接。这里是我的代码:#include"server.h"#include"connection.h"Server::Server(boost::asio::io_service&io_service):accept(io_service,boost::asio::i

c++ - async_resolve 的 boost::asio::ip::tcp::resolver::iterator 的生命周期是多少?

当我调用boost::asio::ip::tcp::resolver::async_resolve时,我的处理程序收到一个ip::tcp::resolver::iterator迭代一个或多个ip::tcp::resolver::entries。他们的生命周期是多少,让他们活着的把柄是什么?例如,如果我得到第一个entry并向它启动一个tcp::async_connect,那么在async_connect处理程序中,可以我迭代到下一个entry并启动另一个async_connect到下一个条目(只要我将iterator传递给async_connect处理程序,当然)?什么时候清理reso

c++ - BOOST-ASIO 阻塞服务器不响应阻塞客户端?

我最近有这个question解决了有问题的服务器,但事实证明服务器似乎没有回复客户端,也没有收到任何发送的数据。这就是我在客户端所做的。C:\blocking_tcp_echo_client\bin\Debug>blocking_tcp_echo_client127.0.0.14001Entermessage:helloException:read:Endoffile这是服务器端。我确实在启动客户端之前启动了服务器。我还用原来的code测试了客户端并且效果很好。C:\boost_server_class\bin\Debug>boost_server_classTCPIP_server: