我尝试使用模板专业化来实现编译时算法选择。
我散列以下代码:
template <class C>
struct choose
{
typedef size_t (*type)(const C*);
static constexpr type value = java_string_hashcode<C>;
};
我已经将这种结构专门用于char
类型:
template <>
struct choose<char>
{
typedef size_t (*type)(const char*);
static constexpr type value = fnv_1a_32_hash;
};
但是当我尝试编译它时,GCC 4.7.1 出现以下错误:
错误:字段初始值设定项不是常量
我认为问题来自fnv_1a_32_hash
函数重载的事实,即使 IMO 隐式转换size_t (*)(const char*)
应该处理这个问题。
我终于找到了一种解决方法,通过重命名重载或简单地转换分配:
static constexpr type value = (type)fnv_1a_32_hash;
我的问题是:这是编译器错误吗?还是我错过了什么?请在需要的地方解释和引用规范。
fnv_1a_32_hash 实现细节:
constexpr size_t fnv_1a_32_hash(const char* p, size_t h) noexcept
{
return (*p == 0) ? h : fnv_1a_32_hash(p + 1, (h ^ *p) * fnv::prime);
}
constexpr size_t fnv_1a_32_hash(const char* p) noexcept
{
return fnv_1a_32_hash(p, fnv::offset_basis);
}