本文介绍了我如何包装std :: wstring在boost :: asio :: buffer?的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!
问题描述
我使用boost :: asio编写一个客户端服务器应用程序。我想将一个结构从客户端传输到服务器。结构体中有一些std :: wstrings。如何在boost :: asio :: buffer中编码结构?
I am writing a client server application using boost::asio. I want to transfer a structure from a client to the server. The struct has a few std::wstrings in it. How do I encode the structure in boost::asio::buffer?
推荐答案
通常我使用 boost :: asio :: streambuf
用于序列化结构。
Typically I use boost::asio::streambuf
for serializing structures.
Message.h
#ifndef MESSAGE_H
#define MESSAGE_H
#include <boost/serialization/string.hpp>
#include <string>
struct Message
{
std::string _a;
std::string _b;
template <class Archive>
void serialize(
Archive& ar,
unsigned int version
)
{
ar & _a;
ar & _b;
}
};
#endif
client.cpp / p>
client.cpp
#include "Message.h"
#include <boost/archive/text_oarchive.hpp>
#include <boost/asio.hpp>
int
main()
{
Message msg;
msg._a = "hello";
msg._b = "world";
boost::asio::streambuf buf;
std::ostream os( &buf );
boost::archive::text_oarchive ar( os );
ar & msg;
boost::asio::io_service io_service;
boost::asio::ip::tcp::socket socket( io_service );
const short port = 1234;
socket.connect(
boost::asio::ip::tcp::endpoint(
boost::asio::ip::address::from_string( "127.0.0.1" ),
port
)
);
const size_t header = buf.size();
std::cout << "buffer size " << header << " bytes" << std::endl;
// send header and buffer using scatter
std::vector<boost::asio::const_buffer> buffers;
buffers.push_back( boost::asio::buffer(&header, sizeof(header)) );
buffers.push_back( buf.data() );
const size_t rc = boost::asio::write(
socket,
buffers
);
std::cout << "wrote " << rc << " bytes" << std::endl;;
}
server.cpp
$ b
server.cpp
#include "Message.h"
#include <boost/archive/text_iarchive.hpp>
#include <boost/asio.hpp>
int
main()
{
boost::asio::io_service io_service;
const uint16_t port = 1234;
boost::asio::ip::tcp::acceptor acceptor(
io_service,
boost::asio::ip::tcp::endpoint(
boost::asio::ip::address::from_string( "127.0.0.1" ),
port
)
);
boost::asio::ip::tcp::socket socket( io_service );
acceptor.accept( socket );
std::cout << "connection from " << socket.remote_endpoint() << std::endl;
// read header
size_t header;
boost::asio::read(
socket,
boost::asio::buffer( &header, sizeof(header) )
);
std::cout << "body is " << header << " bytes" << std::endl;
// read body
boost::asio::streambuf buf;
const size_t rc = boost::asio::read(
socket,
buf.prepare( header )
);
buf.commit( header );
std::cout << "read " << rc << " bytes" << std::endl;
// deserialize
std::istream is( &buf );
boost::archive::text_iarchive ar( is );
Message msg;
ar & msg;
std::cout << msg._a << std::endl;
std::cout << msg._b << std::endl;
}
这篇关于我如何包装std :: wstring在boost :: asio :: buffer?的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持!