函数类型不是模板非类型参数的有效类型

Function type not a valid type for a template non-type parameter?

本文关键字:类型 类型参数 有效 函数      更新时间:2023-10-16
OpenGL定义了C函数来管理资源。我写了一个简单的包装,以RAII的方式处理它们。函数对类似于unsigned glCreateProgram()void glDeleteProgram(unsigned program)。然而,也有一些函数对在void glGenBuffers(size_t n, unsigned* buffers)void glDeleteBuffers(size_t n, const unsigned* buffers);这样的资源数组上工作。对于前者,我编写了一个简单的类来完成这项工作,而对于后者,我又编写了另一个处理数组的类。然而,我注意到,有时我只使用一个缓冲区或纹理,在那里我不必花费向量的费用,我想如果释放函数在开始时使用大小参数,我会专门化类析构函数,但是。。。
template <typename T_res,
typename T_release_func,
T_release_func func>
struct GL_resource
{
GL_resource(T_res name_) : name{name_}
{
}
~GL_resource()
{
func(name);
}
private:
T_res name;
};
template <typename T_res, typename FT, FT func, typename RT, typename DT>
struct GL_resource<T_res, RT (size_t, DT*), func>
{
~GL_resource()
{
func(1, name);
}
};   

对于上述SSCCE g++树皮:

错误:"RT(unsigned int,DT*)"不是模板非类型参数结构GL_resource 的有效类型

然后我编写了一个伪函数void release(size_t, int*) {},并将规范化重写为

template <typename T_res, typename FT, FT func>
struct GL_resource<T_res, decltype(release), release>
{
~GL_resource()
{
func(1, name);
}
};

这次我得到了:

错误:"void(unsigned int,int*)"不是模板非类型参数结构GL_resource的有效类型。

有人能解释一下原因吗?

函数不是值,因此它们不能是非类型模板参数;但是指向函数的指针可以是:

template <typename T_res, typename RT, typename DT, RT (*func) (size_t, DT*)>
struct GL_resource<T_res, RT (*)(size_t, DT*), func>
{
~GL_resource()
{
func(1, name);
}
};   

请注意,即使用作非类型模板参数,函数也会受到指针衰减的影响,因此FT将始终是指向函数类型的指针,而不是函数类型。