我想通过插座发送一个字符。在接收端,它总是以空字符为单位。有什么建议吗?
发送零件
char message[7];
in_addr addr;
inet_aton(splitter_socket_.local_endpoint().address().to_string().c_str(), &addr);
(*(in_addr *)&message) = addr;
(*(uint16_t *)(message + 4)) = htons(splitter_socket_.local_endpoint().port());
(*(char *)(message+6))=htons('M');
splitter_socket_.send(boost::asio::buffer(message));
接收零件
boost::array<char, 7> buf;
char *raw_data = buf.data();
boost::asio::ip::address ip_addr;
int port;
read((*serve_socket), boost::asio::buffer(buf));
in_addr ip_raw = *(in_addr *)(raw_data);
ip_addr = boost::asio::ip::address::from_string(inet_ntoa(ip_raw));
port = ntohs(*(short *)(raw_data + 4));
char sig = ntohs(*(char *)(raw_data+6));
这总是被执行。意思是,sig始终是一个无效的字符但是我寄了" M"。缺少。
if(sig==0){
number_of_monitors_++;
TRACE("The number of monitors increased to "<<number_of_monitors_);
}
我发送的其余数据将被正确收到
您在'M'上进行htons
。
将签名将" M"扩展到一个短,然后(由于您显然在小型机器上)字节汇用,因此您发送的内容是签名扩展的上字节版本,这将是0
,因为保证" M"是正的。
char
不是short
,因此不应将其视为一个。只需传输 char
as-is。