gpt4 book ai didi

c++ - "congruent hash"与 "identity hash"是否有标准名称/模板原型(prototype)?

转载 作者:太空狗 更新时间:2023-10-29 23:16:22 24 4
gpt4 key购买 nike

我有一个模板类 Foo可以进行身份​​比较(通过 == ),但有一个功能 Foo::sameStructureAs(Foo const & other)更多的是“值”与“指针”的平等概念。

我想制作一个 unordered_map 它覆盖了散列函数和相等谓词。它们默认为 std::equal_to<Key>std::hash<Key> ...我根据身份为我的类型提供。但我需要他们根据我的 sameStructureAs 进行比较.

因为 Foo 是一个模板,所以我做这样的事情:

template <class> struct same_structure_as;

template <class> struct hash_structure;

template <class T>
struct hash_structure<Foo<T>>
{
size_t operator() (Foo<T> const & value) const
{
// whatever...
}
};

template <class T>
struct same_structure_as<Foo<T>>
{
bool operator() (Foo<T> const & left, Foo<T> const & right) const
{
// whatever...
}
};

这似乎是我大致遵循 std:: 中类的策略为此目的,并创造一些通用的东西。那么这样看起来对吗?

其次:这个或std::中已经存在的原型(prototype)的命名有没有先例?我想过像 isomorphic 这样的词或 congruent .当您对“平等”的含义有不止一种想法时,这似乎是在设计类时经常出现的问题。

最佳答案

如果您通过这种“不同”的比较或相等概念来查看类型,请问您是否真正需要的是另一种类型。您可能会对基础数据应用某种类型的转换或强制转换,以便其新的相等/赋值/比较概念适合您正在设计的这个测试。

这样您就可以正确地实现该类型的 std::函数...并在集合中使用它而无需传递这些额外的谓词。所以也许调用具有指针相等语义的类型 FooRef和具有值语义的 Foo .

如果由于某种原因你不能这样做......然后看看想要平行的名字:

  • std::equal_to<Key>

  • std::hash<Key>

保持equal_tohash其中可能最接近“标准”的人会完成。所以与其引入像congruence这样的新术语或 isometric , 准确指出什么是相等的或被散列的......并使用上面的作为后缀:

  • std::content_equal_to<Key>

  • std::content_hash<Key>

如果它是被比较的东西的“结构”,你可以用 structure_equal_to 应用它和 structure_hash .唯一需要注意的是,“struct”/“structure”在 C++ 中有意义,因此它可能会让读者认为它在比较 type_info 或类似的东西。

关于c++ - "congruent hash"与 "identity hash"是否有标准名称/模板原型(prototype)?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/24282609/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com