TreeSet

本文深入讲解了Java中TreeSet的两种排序方式:实现Comparable接口的系统排序和实现Comparator接口的人工排序,通过实例演示如何使用Comparator按字符串长度及字典顺序进行排序。
摘要由CSDN通过智能技术生成

         * TreeSet:使用实现了Comparator接口的比较器对象进行比较----人工排序
         * 实例:将字符串按照从短到长排序,长度相同再按照字典排序.
         * 
         * 总结:对TreeSet有两种排序方法
         * 1.实现Comparable接口的compareTo方法---系统排序
         * 2.实现Comparator接口的compare方法---人工排序
         * 
         * 系统让第二种排序的优先级高于第一种,方便人工排序的实现

package com.test;

import java.util.Comparator;
import java.util.TreeSet;
import java.util.concurrent.CancellationException;

public class Demo9 {
	public static void main(String[] args) {
		/*
		 * TreeSet:使用实现了Comparator接口的比较器对象进行比较----人工排序
		 * 实例:将字符串按照从短到长排序,长度相同再按照字典排序.
		 * 
		 * 总结:对TreeSet有两种排序方法
		 * 1.实现Comparable接口的compareTo方法---系统排序
		 * 2.实现Comparator接口的compare方法---人工排序
		 * 
		 * 系统让第二种排序的优先级高于第一种,方便人工排序的实现
		 */
		//第2步.创建比较器对象
		ComWithLength comWithLength=new ComWithLength();
		
		//第3步.将比较器对象TreeSet
		
		TreeSet set =new TreeSet<>(comWithLength);
		set.add("java12");
		set.add("java123");
		set.add("java1234");
		set.add("java1");
		set.add("java456");
		System.out.println(set);//[java1, java12, java123, java456, java1234]
	}
}
//1.创建一个按照字符串长度比较的比较器
//自己设定比较规则
class ComWithLength implements Comparator{

	@Override
	public int compare(Object arg0, Object arg1) {
		if (!(arg0 instanceof String)) {//判断arg0里是否包含String
			throw new ClassCastException("类型转换错误");
		}
		if (!(arg1 instanceof String)) {
			throw new ClassCastException("类型转换错误");
		}
		//向下转型
		String string1=(String)arg0;
		String string2=(String)arg1;
		//将字符串按照从短到长排序,长度相同再按照字典排序.
		int num=string1.length()-string2.length();
		return num==0?string1.compareTo(string2):num;
	}
	
}

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值