缺少模板参数
Missing template argument
我知道这里和网上其他地方也有类似的问题初始化模板函数,但它们没有显示我在做什么错误的
我正在尝试编写一些模板函数来序列化boost::multiarray
和CCD_ 2元素。尝试调用multiarray
模板时出现问题具有以下主体的方法:
save_multi_array
template<class Archive , typename T , std::size_t K>
inline void save_multi_array( Archive &ar , const boost::multi_array<T , K> &t ,
const unsigned int file_version )
{
typedef boost::multi_array<T , K> multi_array_;
typedef typename multi_array_::size_type size_;
for( int k = 0 ; k < K ; ++k ) {
size_ nk = ( t.shape()[ k ] );
ar << BOOST_SERIALIZATION_NVP( nk );
}
ar << boost::serialization::make_array( t.data() , t.num_elements() );
}
load_multi_array:
template<class Archive , typename T , std::size_t K>
inline void load_multi_array( Archive &ar, boost::multi_array<T , K> &t ,
const unsigned int file_version )
{
typedef boost::multi_array<T , K> multi_array_;
typedef typename multi_array_::size_type size_;
boost::array<size_ , K> extents;
for( int k = 0 ; k < K ; ++k )
ar >> BOOST_SERIALIZATION_NVP( extents[ k ] );
t.resize( extents );
ar >> make_array( t.data() , t.num_elements() );
}
serialize_array:
template<class Archive , typename T , int K>
inline void serialize( Archive &ar , boost::multi_array<T , K> &t ,
const unsigned int file_version )
{
split_free( ar , t , file_version );
}
现在,当我在main.cpp
中使用这些方法时,它们工作得很好,但当我试图在我为boost::any
加载和保存编写的模板方法的主体中调用它们时,我会遇到问题。以下是boost::any
部分的模板方法:
保存:
template<class T> struct un_any_type {};
template<std::size_t K> struct un_any_int {};
template<class Archive, typename T, std::size_t K>
inline void save_any (Archive & ar, un_any_type<T>, un_any_int<K> , std::vector<boost::any>::const_iterator &it, const unsigned int file_version)
{
if(K == 0){
if (it->type() ==typeid( T ) ) { //case of saving an object
const std::type_info & ti = it->type();
std::string a = ti.name();
ar << BOOST_SERIALIZATION_NVP(a);
auto var = boost::any_cast< T >( *it );
ar << (var);
}//if
if (it->type() ==typeid( T * ) ) { //case of saving a pointer of an object
const std::type_info & ti = it->type();
std::string a = ti.name();
ar << BOOST_SERIALIZATION_NVP(a);
auto var = boost::any_cast< T * >( *it );
ar << (*var);
}//if
}//if for K-dim
else{
if (it->type() ==typeid( boost::multi_array< T , K > ) ) { //case of saving a multi-dim array
const std::type_info & ti = it->type();
std::string a = ti.name();
ar << BOOST_SERIALIZATION_NVP(a);
/*auto*/ boost::multi_array<T , K> var = boost::any_cast< boost::multi_array<T , K> >( *it );
save_multi_array ( ar , var , version );
}//if
}//if for K-dim
}
装载:
template<class Archive, typename T, std::size_t K>
inline void load_any (Archive & ar, un_any_type<T>, un_any_int<K> , std::vector<boost::any>::iterator it, const unsigned int file_version)
{
if(K == 0){ // case we deal with object, pointer of object, etc
T var;
ar >> (var);
*it = var;
}//if for K-dim
else{
if (it->type() ==typeid( boost::multi_array< T , K > ) ) { //case of saving a multi-dim array
typedef boost::multi_array<T , K> array_type;
array_type var;
load_multi_array(ar, var, version);
}//if
}//if for K-dim
}
当我尝试在这些方法中调用load_multi_array
和save_multi_array
时,我收到错误:
missing template arguments before ‘)’ token
****根据建议的评论进行编辑:
所以,首先感谢您的关心。首先是我目前正在运行的代码,main.cpp可以在以下链接中找到:
https://gist.github.com/anonymous/0464563914dd4b7508e54f199187d4f4
我编写模板函数的头文件可以在这里找到:
https://gist.github.com/anonymous/0f19fdd16100c18244f90f488669640a
您可以在上面的链接中看到对代码的进一步解释,main.cpp首先有所有适当的include(可能有些是不必要的,然后我初始化类gps_position,其中我包括了几种类型的元素,我想检查它们是否序列化,困难的部分是关于boost::multi数组和boost:…any,我需要在其中编写一些代码以使它们可序列化(头文件中包含的方法)。正如您所看到的,有两种方法,一种用于加载,另一种用于保存,因为boost::any vector在保存方法中按顺序保存并传递向量的大小以及boost::any vector中包含的所有不同类型。因此,每个if_case都引用了一个其他类型,该类型预计存在于boost::any中,对于其中的每一个,我们都调用相应的save_any或load_any模板方法,以正确地保存或加载boost::anyvector中的元素。现在问题本身在于这样一个事实,即当在save_any&load_any调用相应的save_multi_array&头文件中模板方法内部的load_multi_array更具体地说:
第88行:
save_multi_array(ar,var,version);
第109行:load_multi_array(ar、var、version);
我收到了上面提到的关于缺少模板参数的错误。最后,控制台中打印的是以下内容:
../src/Multi_Array_Serialization.hpp: In function ‘void boost::serialization::save_any(Archive&, boost::serialization::un_any_type<T>, boost::serialization::un_any_int<K>, std::vector<boost::any>::const_iterator&, unsigned int)’:
../src/Multi_Array_Serialization.hpp:88:46: error: missing template arguments before ‘)’ token save_multi_array ( ar , var , version );
^
../src/Multi_Array_Serialization.hpp: In function ‘void boost::serialization::load_any(Archive&, boost::serialization::un_any_type<T>, boost::serialization::un_any_int<K>, std::vector<boost::any>::iterator, unsigned int)’:
../src/Multi_Array_Serialization.hpp:109:37: error: missing template arguments before ‘)’ token load_multi_array(ar, var, version);
^
最后注意,在主体中,我只是初始化并使用一些不同类型的对象等,我想检查它们是否正确序列化!所以,更详细地说,这就是我的确切问题,我意识到我应该改变我在相应的save_any和load_any模板方法中调用save_multi_array和load_multi_array模板方法的方式(在上面提到的行中),我只是不确定是什么。如果能就如何解决这个问题提出任何建议,我将不胜感激!
您的load_any
函数和save_any
函数都有拼写错误。您打算将整数file_version
传递给load_multi_array
和save_multi_array
,但是您编写了version
。然后编译器认为你指的是
template <class T> struct boost::serialization::version;
该模板确实需要一个模板参数,这就是您收到错误消息的原因。
- 如何反转整数参数包
- 使用C++库在Android项目中修改gradle中的cmake参数,用于插入指令的测试
- 如何使用默认参数等选择模板专业化
- 模板参数替换失败,并且未完成隐式转换
- 具有默认模板参数的多态类的模板推导失败
- lambda参数转换为constexpr技巧,然后获取带链接的数组
- 将数组作为参数传递给函数安全吗?作为第三方职能部门,可以探索他们想要的之外的其他元素
- 函数调用中参数的顺序重要吗
- 部分定义/别名模板模板参数
- 模板-模板参数推导:三个不同的编译器三种不同的行为
- 使用不带参数的函数访问结构元素
- 基于另一个成员参数将函数调用从类传递给它的一个成员
- 如何在OMNET++中指定与命令行参数组合的输出文件名
- 如何使用Luacneneneba API正确读取字符串和表参数
- 在派生函数中指定void*参数
- 视图中的参数推导失败:take_while
- static_assert在宏中,但也可以扩展到可以用作函数参数的东西
- 使用指向成员的指针将成员函数作为参数传递
- 没有名称的C++模板参数
- 如何将enable-if与模板参数和参数包一起使用