【发布时间】:2013-03-11 13:17:17
【问题描述】:
我正在使用 Boost::asio Libs 构建一个 TCP 客户端。我的程序有一个 write() 线程向服务器发送命令
write(*_socket,boost::asio::buffer("sspi l1\n\n",sizeof("sspi l1\n\n")));
然后启动一个读取线程,该线程一直从缓冲区读取,因为任何其他客户端都可能从服务器广播消息
void TCP_IP_Connection::readTCP()
{
size_t l=0;
this->len=0;
boost::system::error_code error;
try
{//loop reading all values from router
while(1)
{
//wait for reply??
l=_socket->read_some(boost::asio::buffer(this->reply,sizeof(this->reply)),error);
if(error)
throw boost::system::system_error(error);
if(l>0)
{
this->dataProcess(l);
}
else
boost::this_thread::sleep(boost::posix_time::milliseconds(5000));
_io.run();
if(error==boost::asio::error::eof) //connection closed by router
std::cout<<"connection closed by router";
_io.reset();
}
}
catch (std::exception& e)
{
std::cerr << e.what() << std::endl;
}
}
这个线程一直在while(1)循环中运行,当接收到的数据长度小于零时应该休眠。它读取所有数据并调用数据解析器函数。之后,写线程用于发送另一个命令,读线程运行。但是服务器发回的不是所需的响应
? ""
ERROR: Unknown command
我尝试使用wireshark。我可以看到命令正在正确发送。我在这里做错了什么?
【问题讨论】:
-
如果您看到发送了正确的命令,那么您为什么认为问题出在发送命令的代码中?如果服务器不接受该命令,则可以肯定该命令是错误的,或者您需要进行一些身份验证。但这与 C++、Boost 或任何相关内容无关。
-
其实我也是这么想的,但是命令是正确的,不存在认证问题。我得到的唯一提示是写缓冲区有问题。但作为一个初学者,我真的不知道我能在那里做什么。
-
你说你有一个读写线程,但我看不到保护你的_socket的互斥锁。也许你有线程问题?如果您在终端程序中手动发送相同的命令会发生什么?
-
如果我使用 netcat 发送,服务器会正确响应。关于互斥锁,是不是要锁定socket进行读写?
-
从接受的答案我想你没有发送正确的命令 - 你发送了命令和一个额外的尾随
\0服务器不是很高兴。
标签: c++ multithreading boost-asio tcpclient