我正在努力学习boost::asio,我和boost::asio::write(),socket->write_some()有一些问题。从我所读到的到现在,我了解到boost::asio::write确保所有数据都是传输的,而socket->write没有这样做,因为它使用的是来自操作系统的send,这并不能保证完整的传输。
这是我的client/server应用程序的一部分。
服务器
void server::session(socket_ptr sock)
{
char data[MAX_SIZE] = {};
bool flag = false;
sprintf(data,"On the server are %d users.",user_vector.size());
//boost::asio::write(*sock, boost::asio::buffer(data, strlen(data)));
sock->write_some(boost::asio::buffer(data, strlen(data)));
cleanMemory(data,strlen(data));
try
{
for (;;)
{
boost::system::error_code error;
size_t length = sock->read_some(boost::asio::buffer(data), error);
//boost::asio::write(*sock, boost::asio::buffer(data,strlen(data)));
cout << std::endl << data;
cleanMemory(data, strlen(data));
if (error == boost::asio::error::eof)
{
std::vector<user_detail>::iterator it = user_vector.begin();
for (; it!= user_vector.end();)
{
std::pair<socket_ptr, int> user = *it;
if (user.first == sock)
{
cout << "User " << user.second << " leave server." << std::endl;
cout << std::endl << "Connection has been closed." << std::endl;
it = user_vector.erase(it);
flag = true;
break;
}
else
++it;
}
if (flag)
break;
}
}
}
catch (const std::exception&e) {
std::cerr << "Error in threead : " << e.what() << endl;
}
}客户端
size_t length = s.read_some(boost::asio::buffer(buf,100)); //OK DATA RECEVIED
//boost::asio::read(s, boost::asio::buffer(buf, 100));//FAIL TO RECEIVE DATA
cout.write(buf,strlen(buf));问题在客户端。如果我用:
size_t length = s.read_some(boost::asio::buffer(buf,100));Works和data是recevide,但如果我使用:
boost::asio::read(s, boost::asio::buffer(buf, 100));数据丢失了。
问题:
boost::asio::write 客户端需要使用boost::asio::read或也可以使用socket.read_some()boost::Asio::read和socket->read_some之间的连接是什么?为什么只有当我使用s.read_some(boost::asio::buffer(buf,100));时才能做到这一点?发布于 2017-09-21 07:50:55
boost::asio::read()会一直读到
( a)已读取所有100个字节,或
( b)有错误,或
( c)有一种断流状态.
这是一种复合操作。其影响之一是,它既可以返回一个错误,也可以读取一些数据。
例如,如果读取50个字节,然后流进入eof条件,则bytes_transferred将为50,返回的error_code将指示文件结束。
对于复合操作,在检查错误之前检查bytes_transferred非常重要。
https://stackoverflow.com/questions/46338147
复制相似问题