从模板参数类型中推导出函数模板参数

Jo *_*tes 5 c++ templates

我目前正在尝试编写一个函数,它将任何类型的STL数组作为其参数之一.写它的显而易见的方法是:

template<typename T, int count>
void setArrayBufferData(GLenum usage, const std::array<T, count>& data) {
  setArrayBufferData(usage, data.data(), sizeof(T) * count);
}
Run Code Online (Sandbox Code Playgroud)

这是另一个重载,它只是作为参考

void setArrayBufferData(GLenum usage, void* data, int size) {
  glBufferData(GL_ARRAY_BUFFER, size, data, usage);
}
Run Code Online (Sandbox Code Playgroud)

函数定义编译得很好.但是,当我试着打电话的时候

std::array<int, 4> data;
setArrayBufferData(GL_STATIC_DRAW, data);
Run Code Online (Sandbox Code Playgroud)

我得到一个"没有匹配函数来调用'setArrayBufferData'"错误消息.我知道如果我在调用中指定模板参数它会工作,但我希望调用推断它们.我已经尝试过研究模板模板参数,一个更通用的声明,然后是std :: array专门化,以及我能想到的所有其他语法变体,但我似乎无法找到一种方法来获得我正在寻找的东西对于.它是否可能,如果可能,还需要做什么?

For*_*veR 7

template<typename T, int count>
void setArrayBufferData(GLenum usage, const std::array<T, count>& data)
Run Code Online (Sandbox Code Playgroud)

是不正确的,因为std :: array是template<typename T, size_t N> struct array.第二个参数必须是类型size_t,而不是int.

另外,data.data()返回const T*,因为数据是对std :: array的const引用,所以,尝试setArrayBufferData(GLenum usage, const void* data, int size)或调用它setArrayBufferData(usage, const_cast<T*>(data.data()), sizeof(T) * count);

#include <array>

void function(const void* ptr, size_t bytes)
{
}

template<typename T, size_t count>
void function(const std::array<T, count>& array)
{
   function(array.data(), sizeof(T) * count);
}

int main()
{
   std::array<int, 4> array;
   function(array);
}
Run Code Online (Sandbox Code Playgroud)

这个例子工作正常.http://liveworkspace.org/code/2a5af492e1f4229afdd0224171854d1c