boost::序列化:是否可以避免模板函数



我有一个来自外部库的结构,我为它编写了一些非侵入式序列化方法。还有这个结构的包装器,我试图将所有依赖项从外部结构保留到这个包装器。问题是,所有序列化方法都是模板,因此它们在头文件中定义,并将依赖项从外部库传播到序列化包装器的每个人,这是我试图避免的。有可能解决这个问题吗?

UPD:最初我有这样的东西:

// serialization.h
#include <external_library.h>
template <typename Archive>
void serialize(Archive& archive, ExternalStruct& external_struct, const unsigned int version) {
    // ...
}

然后我尝试使序列化函数成为特定类型存档的非模板:

// serialization.h
#include <boost/archive/binary_iarchive.hpp>
#include <boost/archive/binary_oarchive.hpp>
struct ExternalStruct;
void serialize(boost::archive::binary_iarchive& archive, ExternalStruct& external_struct, const unsigned int version);
void serialize(boost::archive::binary_oarchive& archive, ExternalStruct& external_struct, const unsigned int version);
// serialization.cpp
#include <external_library.h>
#include "serialization.h"
void serialize(boost::archive::binary_iarchive& archive, ExternalStruct& external_struct, const unsigned int version) {
    // ...
}
void serialize(boost::archive::binary_oarchive& archive, ExternalStruct& external_struct, const unsigned int version) {
    // ...
}

但是后来我收到许多编译错误: no type named 'type' in 'struct boost::mpl::greater<boost::serialization::tracking_level<ExternalStruct>, mpl_::int_<0> >' BOOST_STATIC_WARNING(typex::value);

我认为如果你在头文件中保留模板声明,你会得到更好的代码

// serialization.h
#include <external_library.h>
struct ExternalStruct;
template <typename Archive>
void serialize(Archive& archive, ExternalStruct& external_struct, const unsigned int version);

然后,您将模板实现放入源文件中,以隐藏详细信息:

// serialization.cpp
#include "serialization.h"
#include <external_library.h>
template <typename Archive>
void serialize(Archive& archive, ExternalStruct& external_struct, const unsigned int version) 
{
    // ... details here
}

最后,您将"显式实例化"用于计划使用的特定存档类型。此代码进入与上述相同的源文件。

// serialization.cpp continued 
#include <boost/archive/binary_iarchive.hpp>
#include <boost/archive/binary_oarchive.hpp>
template void serialize(boost::archive::binary_iarchive& archive,
     ExternalStruct& external_struct, const unsigned int version); // explicit instantiation.
template void serialize(boost::archive::binary_oarchive& archive,
     ExternalStruct& external_struct, const unsigned int version); // explicit instantiation.

当然这是可能的。您可以为要使用的每个方法编写自己的函数。

维护起来非常丑陋,但这是一种无需任何模板即可使用的方式。

最新更新