テンプレートの特殊化を使用してコンパイル時のアルゴリズム選択を実装しようとしています。GCC 4.7.1オーバーロードで一般化された定数式の問題
私は次のコードをハッシュ:私はchar
タイプのため、この構造を専門にしました
template <class C>
struct choose
{
typedef size_t (*type)(const C*);
static constexpr type value = java_string_hashcode<C>;
};
を:
template <>
struct choose<char>
{
typedef size_t (*type)(const char*);
static constexpr type value = fnv_1a_32_hash;
};
しかし、私はそれをコンパイルしようとすると、私はGCC 4.7で次のエラーを取得します.1:
error: field initializer is not constant
私はこの問題は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);
}
を全くした場合、私は、エラーメッセージが(過負荷にバグ言及されていないことを思うだろう問題である)。 –