深入学习c++(STL之容器,stdset 第二部分)_recv

class Person {
private:
	int m_age;
	std::string m_name;
public:
	Person(int a, std::string b) : m_age(a), m_name(std::move(b)) {}
	int age() const { return m_age; }
	const std::string& name() const { return m_name;  }
	void print() const { std::cout << "age:" << m_age << " name:" << m_name << std::endl; }
};

struct CompareAge
{
	template<typename T>
	bool operator() (const T &t1, const T &t2) const
	{
		return t1.age() < t2.age();
	}
};
struct CompareName
{
	template<typename T>
	bool operator() (const T &t1, const T &t2) const
	{
		return t1.name() < t2.name();
	}

};

int main()
{
	Person a(15, "abcd");
	Person b(25, "babcd");
	Person c(17, "cendaf");
	std::set<Person, CompareAge> e;
	e.insert(a);
	e.insert(b);
	e.insert(c);
	for ( auto &v : e)
	{
		v.print(); // 如果函数不加const 则不能访问
	}
	std::cout << std::endl;


	std::set<Person, CompareName> g;
	g.insert(a);
	g.insert(b);
	g.insert(c);
	for (auto &v : g)
	{
		v.print();
	}
	std::cout << std::endl;


	Person aa(25, "abcd");
	auto it = g.find(aa);
	if (it != g.end())
	{
		it->print();// 出来的结果 15,abcd  说明是可以查找成功,这是按字母大小来查找,所以25无关,这个需要注意

	}
}

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值