在
怎样用boost::serialization去序列化派生模板类这篇文章中,介绍了序列化派生类模板类,
在写测试用例时一直出现编译错误,调了很久也没跳出来,今天偶然试了一下...居然调了出来。
先看看变异错误的代码(。。。看不出有错,可是编译就有错)。
基类代码:
class base_class
{
public:
base_class(int m=0) : base_member_(0) {}
virtual ~base_class() {}
virtual void print_data() = 0;
private:
class boost::serialization::access;//#1
template<typename Archive>
void serialize(Archive & ar, const unsigned int file_version)//#2
{
ar & BOOST_SERIALIZATION_NVP(base_member_);
//ar & BOOST_SERIALIZATION_NVP(other member...);
}
protected:
int base_member_;
//other member...
};
按照前面几篇的列子:
class base_class
{
public:
base_class(int m=0) : base_member_(0) {}
virtual ~base_class() {}
virtual void print_data() = 0;
private:
class boost::serialization::access;//#1
template<typename Archive>
void serialize(Archive & ar, const unsigned int file_version)//#2
{
ar & BOOST_SERIALIZATION_NVP(base_member_);
//ar & BOOST_SERIALIZATION_NVP(other member...);
}
protected:
int base_member_;
//other member...
};
按照前面几篇的列子:
#1应该声明为友元类(不知道为什么,看看这篇文章boost::serialization 拆分serialize函数)。
#2实现一个serialize函数。这应该没问题???????可是却又问题。后面就知
道了。然后来看看派生模板类的代码:
template<typename T>//#1
class divided_class : public base_class
{
public:
divided_class(int m = 0, T d = T()) : base_class(m), diveded_member_(d) {}
virtual ~divided_
template<typename T>//#1
class divided_class : public base_class
{
public:
divided_class(int m = 0, T d = T()) : base_class(m), diveded_member_(d) {}
virtual ~divided_