C++ map保存自定义类型需要实现的接口

map保存自定义的类型作为key时,要求key可比较,默认情况下,map的模板参数采用的时less来比较,所以需要的是小于的比较。

当然也可以不用编写类的比较函数,通过特化std::less就可以实现自定义类型的比较,这也是非侵入性的,参考:

template<typename... Args> struct std::less<TypeList<Args...> > {
    constexpr bool operator ()(const TypeList<Args...>& ls, const TypeList<Args...>& lm) const {
        return ls.test < lm.test;
    }
};

为map保存TypeList<...>类型实现特化的less,这样就算此类型没有实现比较运算符也可以进行正确比较,只不过是将比较方式放在了less中。

对于无序map类,他们需要key可以被计算为hash值,那么自定义类型也是需要实现hash算法的,参考:

template<typename... Args> struct std::hash<TypeList<Args...> > {
    constexpr auto operator()(const TypeList<Args...>& h) const {
        return h.test;
    }
};

因为默认情况下无序map使用的是hash这个模板类,只要特化指定的类型实现计算就可以了,当然了,你也可以改变使用的hash类,实现自己的哈希类,这样就不需要特化了,当然了,怎么方便怎么来。

一些使用参考示例:

std::unordered_map<TypeList<int>,double> p;
std::map<TypeList<int, double>, std::string> mp;

加我群聊,共同探讨:750965328

 

posted @ 2024-06-03 08:04  大笨瓜  阅读(118)  评论(0)    收藏  举报