[英]defining a non-templated class from a templated class
假设我有一个称为模型的模板化类。 现在让我们在该类中声明一个名为Texture的类,该类不需要模板参数。 我该如何定义它,以便无论给Model类提供的模板参数如何,纹理对象都是相同的。 这就是它的样子。
template<class T>
class Model
{
class Texture;
};
class Model::Texture //error because model requires a template argument.
{
};
所以我能在这里做什么?
您应该这样写:
template<typename T>
class Model<T>::Texture
{
//you should be able to use T here, even though Texture is not a template!
T m_data; //T here
Texture(T data); //T here also, as the constructor parameter!
};
由于Model
是类模板,因此T
仅适用于Model
。 Texture
仍然不是模板。
namespace detail {
class Texture
{
};
}
template<class T>
class Model
{
typedef detail::Texture Texture;
};
detail
名称空间会阻止您的API用户直接访问该类。 如果您不导出任何API,则不必为此担心。 typedef允许通过限定了模板化名称的名称访问非模板化类。
您也可以为此使用通用的非模板祖先:
class ModelBase
{
class Texture;
};
template<class T>
class Model : public ModelBase
{
};
class ModelBase::Texture
{
};
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.