这个模板部分专门化代码有什么问题?
What is wrong with this template partial specialization code?
我使用以下代码:
template<typename t>
struct foo
{
foo(t var)
{
std::cout << "Regular Template";
}
};
template<typename t>
struct foo<t*>
{
foo(t var)
{
std::cout << "partially specialized Template " << t;
}
};
int main()
{
int* a = new int(12);
foo<int*> f(a); //Since its a ptr type it should call specialized template
}
但是我得到错误
Error 1 error C2664: 'foo<t>::foo(int)' : cannot convert parameter 1 from 'int *' to 'int'
两个模板的构造函数的值都是t
,在您的示例中是int
,而不是int*
。使用
template<typename t>
struct foo<t*>
{
foo(t* var)
{
std::cout << "partially specialized Template " << var;
}
};
如果符合您的逻辑,则将int
传递给构造函数。(生活)
相关文章:
- 警告处理为错误这里有什么问题
- C++我的数学有什么问题,为什么我的代码不能正确循环
- 当我尝试添加 2 个大字符串时,我无法弄清楚出了什么问题
- 违反const正确性:我应该现实地期待什么问题
- 这个带有模板<类 Vector 的C++代码片段有什么问题>
- 我的逻辑反转字符串中的元音有什么问题?
- 需要以下代码的帮助,下面的代码有什么问题
- 常量公共成员有什么问题?
- 以下代码中的函数模板有什么问题?
- 这个返回元素位置的基于循环的函数有什么问题?
- creat_list2功能有什么问题?
- 格式说明符C++有什么问题
- 任何人都可以告诉我我的 C++ 代码出了什么问题?
- 从 argv[1] 转换为字符 * 字符串后有什么问题?
- 我的堆栈和库存清单程序的结构有什么问题?
- 此工厂功能有什么问题?
- 以下 C++ 代码有什么问题?
- 数组为此合并排序函数提供了正确的输出,但向量给出了不正确的输出.出了什么问题?
- reinterpret_cast,只读访问,简单的可复制类型,会出什么问题?
- 它解决了什么问题,对于非真空初始化,生命周期在初始化之前就开始了