我对函数模板有疑问。我遇到的错误是:'无法使用以下模板参数专门化函数模板'T sumfun(T &,size_t):coord [3]'。有谁知道如何纠正?我尝试了“模板坐标 sumfun(T &ob, size_t ndim)”,但它会产生更多错误。
template <class T> T sumfun(T &ob, size_t ndim){
T sum();
for(size_t i = 0 ; i <= ndim ; i++)
sum + = ob[i];
return sum;
};
class coord
{
double *crd;
public:
coord(){crd[0]=0;crd[1]=0;};
coord(double xx, double yy) {
alloc();
crd[0] = xx; crd[1] = yy;
}
coord & operator + ( const coord &prawy);
private:
void alloc() {
try {
crd = new double [2];
}catch(bad_alloc) {
}
}
};
coord & coord::operator+(const coord &prawy){
coord tmp(0,0);
tmp.crd[0] = crd[0] + prawy.crd[0];
tmp.crd[1] = crd[1] + prawy.crd[1];
return tmp;
};
int _tmain(int argc, _TCHAR* argv[])
{
coord tab[] = {
coord(0, 0), coord(1,2), coord(2, 1) };
coord sum = sumfun(tab, sizeof(tab)/sizeof(coord));
//cout << sum;
system("pause");
return 0;
}
我不能改变主函数,所以参数必须是这样的:
coord sum = sumfun(tab, sizeof(tab)/sizeof(coord));
最佳答案
问题是您正在传递一个数组,但是传递数组的语法需要它的大小。幸运的是,您可以让模板推导为您计算出大小:
template <class T, std::size_t N>
T sumfun(const T (&ob)[N])
{
T sum = T();
for(std::size_t i = 0 ; i < N ; ++i)
sum += ob[i];
return sum;
}
另请注意,T sum()
是一个函数声明,这就是我将其更改为 T sum = T()
的原因。 T sum{};
也可以。
编辑:如果您无法更改main
,则为ndim
添加第二个参数。然后您可以检查此数字是否不大于 N
:
template <class T, std::size_t N>
T sumfun(const T (&ob)[N], std::size_t ndim)
{
if (ndim > N)
// error, raise an exception or something
T sum = T();
for(std::size_t i = 0 ; i < ndim; ++i)
sum += ob[i];
return sum;
}
当然你也可以用std::accumulate
,作为一个非常懒惰的程序员,这将是我的首选解决方案:
coord sum = std::accumulate(std::begin(tab), std::end(tab), coord());
关于C++ 无法专门化函数模板,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/21770429/