- iOS/Objective-C 元类和类别
- objective-c - -1001 错误,当 NSURLSession 通过 httpproxy 和/etc/hosts
- java - 使用网络类获取 url 地址
- ios - 推送通知中不播放声音
我对嵌套模板及其模板特化有疑问。给定以下类:
一个小模板类
template<class U>
class T {
public:
T(){}
virtual ~T (){}
};
还有一些嵌套模板
template<typename T, template<typename> class U>
class A {
public:
void foo()
{
std::cerr << "A generic foo";
}
};
还有一个小的 main.cpp
int main(int argc, const char *argv[])
{
A<int,T> *a = new A<int,T>;
a->foo();
//This wont work:
A<double,T*> *b = new A<double,T*>;
b->foo();
return 0;
}
如果 U 是指针,现在我需要一个特化:
A<double,T*> *b = new A<double,T*>;
b->foo();
如何实现?我试过类似的东西:
template<typename T, template<typename> class U>
class A< T, U* >
{
public:
void foo()
{
std::cerr << "A specialized foo";
}
};
但它只是解决了
A.h:18:16: Error: Templateargument 2 is invalid
最佳答案
你想做的事是不可能的,因为T*
没有任何意义。它既不是正确的类型,也不匹配需要额外参数的模板。如果U
代表 T*
, 什么会 U<int>
是?你可能是说 T<int>*
但这与您的声明不符,因此无法将该类型插入 A
.
既然你问了一个解决这个问题的方法,我就想到了这样的事情。
接受 A
的第三个模板参数,我称之为 Expander
并将其默认设置为:
template <typename T> struct Expander {
typedef T type;
};
然后,当调用 A
时你可以说
A<int,T> normal;
A<int,T,PtrExpander> pointer;
与
template <typename T> struct PtrExpander {
typedef T* type;
};
和A
会是:
template<typename T, template<typename> class U, template <typename> class E = Expander> class A {
typedef typename E<U<Your_Args_to_U> >::type;
关于c++ - 特化模板<typename T, template<typename> class U>,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/10047780/
我试图任意“绑定(bind)”模板参数,但遇到了一个优雅问题。 直接切入根本问题,gcc 6.2 有以下问题,但逻辑上我认为没有问题...... template P, typename A, typ
我想知道为什么类特化来自 template至 template不支持。 例如: template struct B{}; template struct B{}; //ok template str
我希望以下代码在 foo 从 base 派生任何东西时编译,否则会出现编译错误。我已经编写了类型特征类 is_Base,因为 std::is_base_of 不能很好地与我的模板内容一起使用。我很接近
最近我偶然发现了这样一段代码: template template void SomeClass::Function() {} 有模板函数,但它有奇怪的语法,我不太明白。它有什么作用?附近有没有t
我有一个 vector : std::vector> m_connections 然后我想声明一个由共享指针组成的 vector ,指向与该 vector 以通用方式由弱指针持有的相同类型: std:
探索时this answer我发现采用参数包的模板不会被期望具有特定数量参数的模板的模板接受。 在我看来,这是一个缺陷,因为如果一个模板可以接受任意数量的参数,它应该能够映射到一个特定的数字。有语言律
我需要为我的类获取 2 个类型参数:T1,它是一个具有模板的类,以及 T2,它是 T1 模板的参数。 在我的例子中,一个顶点类型(有 2 个,一个从另一个继承),以及顶点存储的数据类型(在我的例子中是
有时我发现自己需要以下东西: template struct choose{ typedef T1 type; }; template struct choose{ typedef T2 ty
对我来说,编译器可以推导出这样的模板类型看起来很自然: template struct wrap { std::function func_; template wrap(Ar
我对嵌套模板及其模板特化有疑问。给定以下类: 一个小模板类 template class T { public: T(){} virtual ~T (){} }; 还有一些嵌套模板 t
我正在从事一个使用 VS 2008 中内置的测试工具的项目。 我会定期看到类似于以下内容的错误:“AcademyPro.Code.BLL.Appearance”类型的值无法转换为“AcademyPro
代码如下: namespace o { template struct Alias; template inline std::ostream &operator &inst); template
根据文档(https://en.cppreference.com/w/cpp/utility/move),std::move有两种构造函数,在下面发布。 这些构造函数之间有什么区别? 最让我困惑的是,
我有三个 View (AddMatchView、TeamPickerView 和 TeamsOfCountryView)。一切都应该像这样工作:从 AddTeamView 我转到 TeamPicker
关闭。这个问题是not reproducible or was caused by typos .它目前不接受答案。 这个问题是由于错别字或无法再重现的问题引起的。虽然类似的问题可能是on-topi
我试图通过想象神秘的构造来更全面地掌握模板语法和语义。我认为 C++11 标准不允许使用以下语法: template class A {...}; // phony "specialization"
我非常惊讶地发现,当依赖类型作为基类出现时,没有必要添加 typename: struct B {}; struct wr { typedef B type; }; template struct A
我一直在阅读有关删除类型引用的内容,here . 它给出了以下示例: #include // std::cout #include // std::is_same template void pr
一段时间以来,我一直在尝试使用模板,但我做的越多,我意识到我理解的就越少。这个最新的问题感觉就像是我发现了一个相当根本的误解,我开始比以往任何时候都想得更多,“好吧,明天我不应该写任何代码,而是找一个
以下是代码,引用自 Addison Wesley 的 C++ 模板: template class MyClass { typename T::SubType * ptr;
我是一名优秀的程序员,十分优秀!