我可以从模板类中提取C++模板参数吗?

drp*_*per 3 c++ templates metaprogramming

基本上,给定一个这样的模板类:

template< class Value > class Holder { }; 
Run Code Online (Sandbox Code Playgroud)

我希望能够发现Value给定Holder类的类型.我以为我能够创建一个带有模板模板参数的简单元函数,如下所示:

template< template< class Value > class Holder > class GetValue
{
    typedef Value Value;
};
Run Code Online (Sandbox Code Playgroud)

然后提取出这样的Value类型:

GetValue< Holder< int > >::Value value;
Run Code Online (Sandbox Code Playgroud)

但我只是得到一个指向元函数声明的错误消息:

error: ‘Value’ does not name a type
Run Code Online (Sandbox Code Playgroud)

有没有办法完成这种事情?谢谢.

[编辑]我也收到错误消息:

error: type/value mismatch at argument 1 in template parameter list for ‘template<template<class Value> class Holder> class GetValue’
error:   expected a class template, got ‘Holder<int>’
Run Code Online (Sandbox Code Playgroud)

这让我得出结论,Phil Nash是对的,你不能将一个类作为模板模板参数传递.

Seb*_*ian 11

为什么不简单地将持有者类改为

template< class Value > class Holder {
    typedef Value value_type;

    value_type m_val; // member variable
};
Run Code Online (Sandbox Code Playgroud)

在任何使用Holder <T>类型的对象的方法中,您可以访问包含的类型:

template< class THolder >
void SomeMethod( THolder const& holder ) {
     typename THolder::value_type v = holder.m_val;
}
Run Code Online (Sandbox Code Playgroud)

这种方法遵循所有STL类使用的模式,例如,std :: vector <int> :: value_type是int.

我想你正在尝试进行部分模板专业化:

template<class T>
class GetValue {
};

template<class Value>
class GetValue< Holder<Value> > {
public:
    typedef Value value_type;
};
Run Code Online (Sandbox Code Playgroud)

在您的代码中,您可以执行以下操作:

template<class THolder>
void SomeMethod( THolder const& h ) {
    typename GetValue< THolder >::value_type v = h.m_v;
}
Run Code Online (Sandbox Code Playgroud)

总的来说,我更喜欢第一种解决方案.