在我的程序中,我想为此目的定义IPAddressV4的新数据类型,我定义了以下类:
#include <boost/array.hpp>
#include <boost/asio.hpp>
#include "archive.hpp"
using boost::asio::ip::address_v4;
typedef boost::uint8_t uint8; /**< 8-bit unsigned interger. */
class IPAddrV4
{
public:
/**
* Construct a IPAddrV4 data type.
*/
IPAddrV4() : _ip_address(0)
{}
/**
* Construct a IPAddrV4 data type.
*
* @param ip_address The value of the IPv4 Address in text format.
*/
IPAddrV4(std::string ip_address) : _ip_address(0)
{
*this = ip_address;
}
/**
* Set the IPv4 Address value.
*
* @param val The value of the IPv4 Address in text format.
* @return The reference to the IPAddrV4 data type.
*/
IPAddrV4& operator=(std::string ip_address)
{
boost::asio::ip::address_v4::bytes_type bytes
= boost::asio::ip::address_v4::from_string(ip_address).to_bytes();
_ip_address = ((uint32(bytes.at(0)) << 24) |
(uint32(bytes.at(1)) << 16) |
(uint32(bytes.at(2)) << 8) |
uint32(bytes.at(3)));
return *this;
}
IPAddrV4& operator=(uint32 ip_address)
{
_ip_address = ip_address;
return *this;
}
/**
* Get the IPv4 Address data type value.
*
* @return The IPv4 Address data type value in binary form.
*/
operator uint32()
{
return _ip_address;
}
private:
uint32 _ip_address;
};
后来我正在使用这个类进行一些序列化和反序列化,以通过TCP连接发送数据。 当我使用输出存档进行序列化时,我没有任何问题。
IPAddrV4 ip("127.0.0.1");
oarchive & ip;
在上面的示例中,IP的值将转换为二进制形式,然后复制到输出存档。并且oarchive将其大小增加4个字节。
但是当我尝试将此数据类型与输入存档一起用于序列化时,我遇到了问题:
IPAddrV4 ip;
iarchive & ip;
这是我在编译时得到的错误:
No match for 'operator&' in 'input_Archive & IPAddrV4::operator uint32()'
那么我在IPAddrV4中缺少什么?
注意:输入存档与标准c ++数据类型完美配合,如uint,string..etc。
答案 0 :(得分:1)
为此,Boost序列化具有BOOST_STRONG_TYPEDEF
。
另见
答案 1 :(得分:1)
我发现了错误,我必须将运算符uint32()
的重载更改为uint32&()
,如下所示:
operator uint32 &()
{
return _ip_address;
}
通过这种方式,我通过引用而不是输入存档的值返回值。