C++ 无法专门化函数模板

标签 c++ function templates

我对函数模板有疑问。我遇到的错误是:'无法使用以下模板参数专门化函数模板'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/

相关文章:

c++ - std::vector Reserve() 的未定义行为

objective-c - Objective C 类方法与 C 函数

c++ - C++ 模板元编程的最佳介绍?

c++ - 如何开始学习 C++ 中的图形?

c++ - 如何将元函数应用于可变模板类的模板类型?

c++ - 单例的段错误

C++ - 语句无法解析重载函数的地址

java - 在 int 函数中返回 2 个整数

C++ 模板集合类型

node.js - 如何迭代 SendGrid 模板中的对象数组?