您的位置:首页 > 房产 > 建筑 > C++智能指针配合STL模板类

C++智能指针配合STL模板类

2025/1/13 11:47:20 来源:https://blog.csdn.net/qq_30220519/article/details/141401752  浏览:    关键词:C++智能指针配合STL模板类
代码 

#include <unordered_map>
#include <set>
#include <memory>
class ResID {
public:using SP = std::shared_ptr<ResID>;ResID() = default;ResID(const std::string& id, const std::string& type): m_id(id), m_type(type){}public:~ResID() = default;bool isValid() const { return !m_id.empty() && !m_type.empty(); };bool isEqual(const ResID& other) const{return m_id == other.m_id && m_type == other.m_type;}std::string type() const { return m_type; }std::string id() const { return m_id; }void setType(const std::string& type) { m_type = type; }void setId(const std::string& id) { m_id = id; }// 自定义比较器struct Compare {bool operator()(ResID::SP lhs, ResID::SP rhs) const{// 根据`value`成员变量进行比较return std::tuple(lhs->type(), lhs->id()) < std::tuple(lhs->type(), lhs->id());}};using Set = std::set<ResID::SP, ResID::Compare>;// 自定义比较器struct Equal {bool operator()(ResID::SP lhs, ResID::SP rhs) const{return lhs->isEqual(*rhs);}};// 自定义比较器struct Hash {size_t operator()(ResID::SP lhs) const{return std::hash<std::string>()(lhs->type()) ^ std::hash<std::string>()(lhs->id());}};template<class T>using UMap= std::unordered_map<ResID::SP, T, ResID::Hash, ResID::Equal>;private:std::string m_id;std::string m_type;
};
示例

class Data{
public:
int value;
};auto resID = std::make_shared<ResID>("id", "type");
auto resID2 = std::make_shared<ResID>("id2", "type2");
ResID<Data>::UMap uMap;
uMap.emplace(resID, {});
uMap.emplace(resID2, {});
uMap.emplace(resID, {});
assert(uMap.size() == 2);

创作不易,小小的支持一下吧!

版权声明:

本网仅为发布的内容提供存储空间,不对发表、转载的内容提供任何形式的保证。凡本网注明“来源:XXX网络”的作品,均转载自其它媒体,著作权归作者所有,商业转载请联系作者获得授权,非商业转载请注明出处。

我们尊重并感谢每一位作者,均已注明文章来源和作者。如因作品内容、版权或其它问题,请及时与我们联系,联系邮箱:809451989@qq.com,投稿邮箱:809451989@qq.com