template <class ContainerType, class elementType>
void SerializeContainer ( ContainerType< elementType > container )
{
}
//call like this
std::vector<int> vector;
SerializeContainer(vector);
下面的将无法编译..有什么方法可以解决这个问题吗?
答案 0 :(得分:5)
使用容器的value_type
成员提取元素类型更容易:
template <typename T>
void SerializeContainer (const T& container)
{
typedef typename T::value_type ElementType;
..........
}
您的代码无效的原因是因为语法ContainerType<ElementType>
仅在ContainerType
是真正的模板时有效。 C ++支持模板模板参数:
template <template <typename> class ContainerType, typename ElementType>
void serializeContainer(const ContainerType<ElementType>& container) {
}
但即使这样,也不会匹配标准C ++容器,因为有一些隐藏的默认参数。明确写明时:
std::vector<int,
std::allocate<int> > vector;
因此,您需要使ContainerType参数接受2个参数:
template <typename <typename, typename> C, typename E, typename A>
void serializeContainer(const C<E, A>& container) {
}
但是这与set::set
不匹配,因为它有不同数量的模板参数:
std::set<int,
std::less<int>,
std::allocator<int> > set;
如果您希望在匹配时明确拼写ElementType,那么根本没有一个适合所有人的解决方案(在C ++ 11之前)。坚持使用容器提供的特性更好。