Java中TreeSet使用Lambda和比较类的方法

package CollectionTest;

import java.util.TreeSet;

import java.util.Comparator;  

class M
{
	int age;
	public M(int age)
	{
		this.age = age;
	}
	public String toString()
	{
		return "M[age:" + age + "]";
	}
}
public class TreeSetDemo
{
	public static void main(String[] args)
	{
	   MDemo1();
	   MDemo2();
	   MDemo3();
	}
	
	public static  void MDemo1(){  
		 //使用Lambda
		// 此处Lambda表达式的目标类型是Comparator
				TreeSet<M> ts = new TreeSet<M>((o1 , o2) ->
				{
					M m1 = (M)o1;
					M m2 = (M)o2;
					// 根据M对象的age属性来决定大小,age越大,M对象反而越小
					return m1.age > m2.age ? -1
						: m1.age < m2.age ? 1 : 0;
				});
				ts.add(new M(5));
				ts.add(new M(-3));
				ts.add(new M(9));
				System.out.println(ts);
	}
	
	public static  void MDemo2(){  
		 //使用比较类,不用变更M类,而是建立比较类,作为参数传递给TreeSet
				TreeSet<M> ts = new TreeSet<M>(new MComparator());
				ts.add(new M(5));
				ts.add(new M(-3));
				ts.add(new M(9));
				System.out.println(ts);
	}
	
	public static  void MDemo3(){  
		 //使用比较类,不用变更M类,而是建立比较类,作为参数传递给TreeSet
				TreeSet<M2> ts = new TreeSet<M2>();
				ts.add(new M2(5));
				ts.add(new M2(-3));
				ts.add(new M2(9));
				System.out.println(ts);
	}
}
class MComparator implements Comparator<M>{

	@Override
	public int compare(M o1, M o2) {
		
		return o1.age-o2.age;
	}
	
}

//若使用compareTo方法就要改变M类
class M2 implements   Comparable<M2>
{
	int age;
	public M2(int age)
	{
		this.age = age;
	}
	public String toString()
	{
		return "M2[age:" + age + "]";
	}
	@Override
	public int compareTo(M2 o) {
		// TODO Auto-generated method stub
		return this.age-o.age;
	}
}

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值