溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

Java 中 Collections.sort()的應(yīng)用方法

發(fā)布時(shí)間:2021-06-18 16:51:28 來(lái)源:億速云 閱讀:174 作者:chen 欄目:編程語(yǔ)言

本篇內(nèi)容主要講解“Java 中 Collections.sort()的應(yīng)用方法”,感興趣的朋友不妨來(lái)看看。本文介紹的方法操作簡(jiǎn)單快捷,實(shí)用性強(qiáng)。下面就讓小編來(lái)帶大家學(xué)習(xí)“Java 中 Collections.sort()的應(yīng)用方法”吧!

關(guān)于 Java 中 Collections.sort()方法 的使用<comparable 、 compareTo>

例如

public static void main(String[] args) {
    List<String> list = new ArrayList<String>();
    list.add("abc");
    list.add("abb");
    list.add("bcd");
    Collections.sort(list,new Comparator<String>() {
        @Override
        public int compare(String o1, String o2) {
            /**
			升序排序是 第一個(gè)參數(shù).compareTo(第二個(gè)參數(shù));
			降序排序是 第二個(gè)參數(shù).compareTo(第一個(gè)參數(shù));
			*/
            return o2.compareTo(o1);
        }
    });
    System.out.println(list);
}
輸出: [bcd, abc, abb]

第一種:Comparable 排序接口

  • 如果一個(gè)類(lèi)實(shí)現(xiàn)了Comparable接口,就意味著"該類(lèi)支持排序"。

  • 實(shí)現(xiàn)Comparable接口,重寫(xiě)compareTo()方法實(shí)現(xiàn)排序

/*   User實(shí)體類(lèi)  */
public class User implements Comparable<User>{
	private int id;
	private String name;
	private int age;
	public User(){}
	public User(int id, String name, int age) {
		super();
		this.id = id;
		this.name = name;
		this.age = age;
	}
	
	public int getId() {	return id;	}

	public void setId(int id) {		this.id = id;	}

	public String getName() {	return name;	}

	public void setName(String name) {	this.name = name;	}

	public int getAge() {	return age;	}

	public void setAge(int age) {	this.age = age;	}
	
	@Override
	public int compareTo(User u) {
        // 按age排序,也可按照其他成員變量排序
		return this.age - u.getAge(); // 升序
//		return u.getAge() - this.age; //降序
	}
	@Override
	public String toString() {
		return "User [id=" + id + ", name=" + name + ", age=" + age + "]";
	}
}


/*  Test測(cè)試類(lèi)  */
ublic class Test {
	public static void main(String[] args) {
		List<User> list = new ArrayList<User>();
		User user1 = new User(1,"aaaa",14);
		User user2 = new User(2,"bbbb",21);
		User user3 = new User(3,"cccc",12);
		User user4 = new User(4,"dddd",16);
		User user5 = new User(5,"eeee",9);
		list.add(user1);
		list.add(user2);
		list.add(user3);
		list.add(user4);
		list.add(user5);
		/* 
		list中的對(duì)象User實(shí)現(xiàn)了Comparable接口,含有compareTo()方法,
			所以可以直接調(diào)用Collections.sort()方法進(jìn)行排序
		*/
		Collections.sort(list);
		System.out.println(list);
	}
}
輸出結(jié)果:[User [id=5, name=eeee, age=9], User [id=3, name=cccc, age=12], User [id=1, name=aaaa, age=14], User [id=4, name=dddd, age=16], User [id=2, name=bbbb, age=21]]

第二種:Comparator比較器接口

  • 如果我們需要對(duì)某個(gè)類(lèi)排序,但該類(lèi)本身不支持排序(即沒(méi)有實(shí)現(xiàn)Comparable接口),可使用Comparator比較器接口。

  • 實(shí)體類(lèi)不用實(shí)現(xiàn)Comparable接口

/*   User實(shí)體類(lèi)  */
public class User{
	private int id;
	private String name;
	private int age;
	public User(){}
	public User(int id, String name, int age) {
		super();
		this.id = id;
		this.name = name;
		this.age = age;
	}
	
	public int getId() {	return id;	}

	public void setId(int id) {		this.id = id;	}

	public String getName() {	return name;	}

	public void setName(String name) {	this.name = name;	}

	public int getAge() {	return age;	}

	public void setAge(int age) {	this.age = age;	}
	
	@Override
	public String toString() {
		return "User [id=" + id + ", name=" + name + ", age=" + age + "]";
	}
}

/*  Test測(cè)試類(lèi)  */
public class Test {
	public static void main(String[] args) {
		List<User> list = new ArrayList<User>();
		User user1 = new User(1,"aaaa",14);
		User user2 = new User(2,"bbbb",21);
		User user3 = new User(3,"cccc",12);
		User user4 = new User(4,"dddd",16);
		User user5 = new User(5,"eeee",9);
		list.add(user1);
		list.add(user2);
		list.add(user3);
		list.add(user4);
		list.add(user5);
		/* 
		list中的對(duì)象User沒(méi)有實(shí)現(xiàn)了Comparable接口,
			通過(guò)重載Collections.sort()方法實(shí)現(xiàn)排序
		*/
		Collections.sort(list,new Comparator<User>() {
			@Override
			public int compare(User u1, User u2) {
				//return u2.getAge()-u1.getAge(); // 降序
				// return u1.getAge()-u2.getAge();  // 升序
				return u2.getName().compareTo(u1.getName()); // 名字降序
			}
		});
		System.out.println(list);
	}
}
輸出結(jié)果:[User [id=5, name=eeee, age=9], User [id=4, name=dddd, age=16], User [id=3, name=cccc, age=12], User [id=2, name=bbbb, age=21], User [id=1, name=aaaa, age=14]]

總結(jié):前者代碼結(jié)構(gòu)簡(jiǎn)單,但是只能根據(jù)固定的屬性排序; 后者靈活,可以臨時(shí)指定排序項(xiàng),但是代碼不夠簡(jiǎn)潔

到此,相信大家對(duì)“Java 中 Collections.sort()的應(yīng)用方法”有了更深的了解,不妨來(lái)實(shí)際操作一番吧!這里是億速云網(wǎng)站,更多相關(guān)內(nèi)容可以進(jìn)入相關(guān)頻道進(jìn)行查詢,關(guān)注我們,繼續(xù)學(xué)習(xí)!

向AI問(wèn)一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI