Boost Asioserver使用

今天主要想说道说道boost里面的网络通信库怎样设计和使用,由于近期一直在和网络一起工作,大数据处理和机器学习都离不开最后使用网络进行上线部署。先看看所有的源码吧。

#include <cstdlib>
#include <iostream>
#include <memory>
#include <utility>
#include <boost/asio.hpp>
#include <stdint.h>
#include "data.h"
#include <ostream>
#include <boost/archive/binary_iarchive.hpp>
#include <boost/archive/binary_oarchive.hpp>

using boost::asio::ip::tcp;

class session
	: public std::enable_shared_from_this < session >
{
public:
	session(boost::asio::ip::tcp::socket socket)
		: socket_(std::move(socket))
	{
	}

	void start()
	{
		do_read();
	}

private:
	void do_read()
	{
		auto self(shared_from_this());

		//int32_t data_length;
		boost::asio::async_read(socket_, 
			boost::asio::buffer(&data_length, 4),
			[this, self](boost::system::error_code ec, std::size_t length)
		{
			if (!ec)
			{
				do_read_body();
			}
		});
	}
	void do_read_body()
	{
		
		auto self(shared_from_this());
		boost::asio::async_read(socket_,
			buf_, boost::asio::transfer_exactly(data_length),
			[this, self](boost::system::error_code ec, std::size_t length)
		{
			std::cout << length<<std::endl;
			if (!ec)
			{
				ProcessMessage();
				do_read();
			}
			else
			{
				std::cout << "error" << std::endl;
			}
		});
	};

	void ProcessMessage()
	{
		boost::archive::binary_iarchive ia(buf_);
		translate_data message;
		ia >> message;
		std::cout << message.width<<std::endl;
	};


	int32_t data_length;

	boost::asio::ip::tcp::socket socket_;

	boost::asio::streambuf buf_;
};

class server
{
public:
	server(boost::asio::io_service& io_service, short port)
		: acceptor_(io_service, boost::asio::ip::tcp::endpoint(tcp::v4(), port)),
		socket_(io_service)
	{
		do_accept();
	}

private:
	void do_accept()
	{
		acceptor_.async_accept(socket_,
			[this](boost::system::error_code ec)
		{
			if (!ec)
			{
				std::make_shared<session>(std::move(socket_))->start();
			}

			do_accept();
		});
	}

	boost::asio::ip::tcp::acceptor acceptor_;
	boost::asio::ip::tcp::socket socket_;
};

int main(int argc, char* argv[])
{
	try
	{
		/*if (argc != 2)
		{
			std::cerr << "Usage: async_tcp_echo_server <port>\n";
			return 1;
		}*/

		boost::asio::io_service io_service;

		server s(io_service, 8888);

		io_service.run();
	}
	catch (std::exception& e)
	{
		std::cerr << "Exception: " << e.what() << "\n";
	}

	return 0;
}
这个就是服务区的所有源码。

data是消息的数据格式,translate_data 这个类的定义,该类能够使用boost进行序列化。整个消息处理起来很的流畅,能够使得我们仅仅关心数据流,而忽略server怎样异步接收消息。当然我的演示样例代码中的数据格式很之简单,数据包开头的int表示数据有多少个字节。索性连我的消息代码一起放出来:

#include <boost/serialization/array.hpp>
#include <boost/serialization/vector.hpp>

struct MeasurementZ
{
	double m_a[3];
	double m_w[3];
	double m_t;
	friend class boost::serialization::access;

	template<class Archive>
	void serialize(Archive& ar, const unsigned int version)
	{
		ar & boost::serialization::make_array(m_a, 3 * sizeof(double));
		ar & boost::serialization::make_array(m_w, 3 * sizeof(double));
		ar & m_t;
	}
};

struct translate_data
{
	int width;
	int height;
	double mt;
	int N;
	unsigned char* buffer;//640*480;
	
	std::vector<MeasurementZ> z;
	std::vector<double> Quaterniond;//4
	std::vector<double> Vector3d;//3
	double M_rM_t;
};
BOOST_SERIALIZATION_SPLIT_FREE(translate_data)
namespace boost
{
	namespace serialization
	{
		/** Serialization support for cv::Mat */
		template<class Archive>
		void save(Archive & ar, const translate_data& m, const unsigned int version)
		{
			ar & m.width;
			ar & m.height;
			ar & m.mt;
			ar & m.N;
			
			const size_t data_size = m.width * m.height*sizeof(unsigned char);
			ar & boost::serialization::make_array(m.buffer, data_size);
			ar & m.z;
			ar & m.Quaterniond;
			ar & m.Vector3d;
			ar & m.M_rM_t;
		}    /** Serialization support for cv::Mat */
		template <class Archive>
		void load(Archive & ar, translate_data& m, const unsigned int version)
		{
			ar & m.width;
			ar & m.height;
			ar & m.mt;
			ar & m.N;

			const size_t data_size = m.width * m.height*sizeof(unsigned char);
			m.buffer = new unsigned char[m.width*m.height];
			ar & boost::serialization::make_array(m.buffer, data_size);
			ar & m.z;
			ar & m.Quaterniond;
			ar & m.Vector3d;
			ar & m.M_rM_t;
		}
	}
};


整个project很easy,请有用c++11标准来完毕。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Boost库的使用案例可以通过以下步骤进行: 1. 下载和安装Boost库:首先,你需要从Boost官方网站下载并解压Boost库的压缩包[1]。然后,进入解压后的目录,并执行bootstrap.sh脚本来配置Boost库的编译选项[3]。最后,使用b2命令编译并安装Boost库[3]。 2. 包含头文件:大多数Boost库只需要在你的源代码中包含相应的头文件即可[2]。例如,如果你想使用boost::tribool库,只需要在你的C源文件中添加以下include语句: ```cpp #include <boost/XXX.hpp> #include <boost/logic/tribool.hpp> //使用tribool库 ``` 3. 使用Boost库:一旦你包含了所需的头文件,你就可以使用Boost库提供的功能了。你可以根据你的需求使用不同的Boost库组件,比如算法库、时间处理库、异步并发库等[1]。 下面是一个使用Boost库的简单示例,展示了如何使用boost::tribool库来处理三态逻辑值: ```cpp #include <iostream> #include <boost/logic/tribool.hpp> int main() { boost::logic::tribool value = boost::logic::indeterminate; // 初始化为不确定状态 if (value) { std::cout << "Value is true" << std::endl; } else if (!value) { std::cout << "Value is false" << std::endl; } else { std::cout << "Value is indeterminate" << std::endl; } return 0; } ``` 在这个示例中,我们使用boost::logic::tribool库来定义一个三态逻辑值。我们将其初始化为不确定状态,并根据其值输出相应的信息。 希望这个示例能帮助你理解如何使用Boost库。你可以根据自己的需求选择合适的Boost库组件,并在你的代码中包含相应的头文件来使用它们[1][2]。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值