Sort a List in Java - Java 147

Sort a List in Java – Java 147

Sort a List in Java

在 Java 中對資料進行排序的最常見的幾個方法,是使用 Collections sort 、 List sort 、 Stream sorted 等方法,預設情況下,會按升序對集合進行排序,讓資料便更容易理解、搜尋和處理, Sort List Example 提供了預設比較器和建立自定義比較器,比較兩個物件並傳回一個整數,指示它們的相對順序,本篇增加了範例,並透過單元測試來驗證產出結果。

檔案目錄

./
   +- src
       +- test
       |   +- org
       |       +- ruoxue
       |           +- java_147
       |               +- list
       |                   +- sort
       |                       +- SortListTest.java   

單元測試

Java List Sort 提供不同類型的資料進行排序,使用預設或自定義比較器,排序集合中的元素。

Fruit

建立 Fruit 類別,覆寫 toString ,定義屬性和方法,用來建立一個物件。

	@NoArgsConstructor
	@Getter
	@Setter
	@Builder
	public static class Fruit {

		private String name;
		private double quantity;
		private int type;

		public Fruit(String name, double quantity, int type) {
			this.name = name;
			this.quantity = quantity;
			this.type = type;
		}

		public String toString() {
			ToStringBuilder builder = new ToStringBuilder(this, ToStringStyle.JSON_STYLE);
			builder.appendSuper(super.toString());
			builder.append("name", name);
			builder.append("quantity", quantity);
			builder.append("type", type);
			return builder.toString();
		}
	}

Collections_sort

Java List Sort 建立一個 List ,增加三個元素,使用 Collections sort 方法,依照預設比較器,由小到大,升序對集合進行排序。

	@Test
	public void Collections_sort() {
		List<String> list = Arrays.asList("Orange", "Mango", "Peach");
		System.out.println(list);

		Collections.sort(list);
		System.out.println(list);
		assertThat(list).containsExactly("Mango", "Orange", "Peach");
	}
[Orange, Mango, Peach]
[Mango, Orange, Peach]

Collections_sort_withComparator

Java List Sort 建立一個 List ,增加三個元素,使用 Collections sort 方法,依照自定義比較器,由小到大,升序對集合進行排序。

	@Test
	public void Collections_sort_withComparator() {
		List<Double> list = Arrays.asList(Double.MAX_VALUE, -1d, 3d);
		System.out.println(list);

		Collections.sort(list, (i1, i2) -> Double.compare(i1, i2));
		System.out.println(list);
		assertThat(list).containsExactly(-1d, 3d, Double.MAX_VALUE);
	}
[1.7976931348623157E308, -1.0, 3.0]
[-1.0, 3.0, 1.7976931348623157E308]

Collections_sort_withComparing

Java List Sort 建立一個 List ,增加三個元素,使用 Collections sort 方法,依照物件屬性,由小到大,升序對集合進行排序。

	@Test
	public void Collections_sort_withComparing() {
		Fruit orange = new Fruit("Orange", -1, 3);
		Fruit mango = new Fruit("Mango", Double.MAX_VALUE, 1);
		Fruit peach = new Fruit("Peach", 3, 1);
		List<Fruit> list = new ArrayList<>(Arrays.asList(orange, mango, peach));
		System.out.println(list);

		Collections.sort(list, Comparator.comparing(Fruit::getQuantity));
		System.out.println(list);
		assertThat(list).containsExactly(orange, peach, mango);
	}
[{"name":"Orange","quantity":-1.0,"type":3}, {"name":"Mango","quantity":1.7976931348623157E308,"type":1}, {"name":"Peach","quantity":3.0,"type":1}]
[{"name":"Orange","quantity":-1.0,"type":3}, {"name":"Peach","quantity":3.0,"type":1}, {"name":"Mango","quantity":1.7976931348623157E308,"type":1}]

List_sort

Java Sort List with Examples 建立一個 List ,增加三個元素,使用 List sort 方法,依照預設比較器,由小到大,升序對集合進行排序。

	@Test
	public void List_sort() {
		List<String> list = Arrays.asList("Banana", "Apple", "Cherry");
		System.out.println(list);

		list.sort(null);
		System.out.println(list);
		assertThat(list).containsExactly("Apple", "Banana", "Cherry");
	}
[Banana, Apple, Cherry]
[Apple, Banana, Cherry]

List_sort_withComparator

Java Sort List with Examples 建立一個 List ,增加三個元素,使用 List sort 方法,依照自定義比較器,由小到大,升序對集合進行排序。

	@Test
	public void List_sort_withComparator() {
		List<Double> list = Arrays.asList(Double.MAX_VALUE, -1d, 3d);
		System.out.println(list);

		list.sort((i1, i2) -> Double.compare(i1, i2));
		System.out.println(list);
		assertThat(list).containsExactly(-1d, 3d, Double.MAX_VALUE);
	}
[1.7976931348623157E308, -1.0, 3.0]
[-1.0, 3.0, 1.7976931348623157E308]

List_sort_withComparing

Java Sort List with Examples 建立一個 List ,增加三個元素,使用 List sort 方法,依照物件屬性,由小到大,升序對集合進行排序。

	@Test
	public void List_sort_withComparing() {
		Fruit banana = new Fruit("Banana", -1, 3);
		Fruit apple = new Fruit("Apple", Double.MAX_VALUE, 1);
		Fruit cherry = new Fruit("Cherry", 3, 1);
		List<Fruit> list = new ArrayList<>(Arrays.asList(banana, apple, cherry));
		System.out.println(list);

		list.sort(Comparator.comparing(Fruit::getQuantity));
		System.out.println(list);
		assertThat(list).containsExactly(banana, cherry, apple);
	}
[{"name":"Banana","quantity":-1.0,"type":3}, {"name":"Apple","quantity":1.7976931348623157E308,"type":1}, {"name":"Cherry","quantity":3.0,"type":1}]
[{"name":"Banana","quantity":-1.0,"type":3}, {"name":"Cherry","quantity":3.0,"type":1}, {"name":"Apple","quantity":1.7976931348623157E308,"type":1}]

Stream_sorted

List Sort in Java 建立一個 List ,增加三個元素,使用 Stream sorted 方法,依照預設比較器,由小到大,升序對集合進行排序。

	@Test
	public void Stream_sorted() {
		List<String> list = Arrays.asList("Lichee", "Coconut", "Plum");
		System.out.println(list);

		ArrayList<String> result = list.stream().sorted().collect(Collectors.toCollection(ArrayList::new));
		System.out.println(result);
		assertThat(result).containsExactly("Coconut", "Lichee", "Plum");
	}
[Lichee, Coconut, Plum]
[Coconut, Lichee, Plum]

Stream_sorted_withComparator

List Sort in Java 建立一個 List ,增加三個元素,使用 Stream sorted 方法,依照自定義比較器,由小到大,升序對集合進行排序。

	@Test
	public void Stream_sorted_withComparator() {
		List<Double> list = Arrays.asList(Double.MAX_VALUE, -1d, 3d);
		System.out.println(list);

		ArrayList<Double> result = list.stream().sorted((i1, i2) -> Double.compare(i1, i2))
				.collect(Collectors.toCollection(ArrayList::new));
		System.out.println(result);
		assertThat(result).containsExactly(-1d, 3d, Double.MAX_VALUE);
	}
[1.7976931348623157E308, -1.0, 3.0]
[-1.0, 3.0, 1.7976931348623157E308]

Stream_sorted_withComparing

List Sort in Java 建立一個 List ,增加三個元素,使用 Stream sorted 方法,依照物件屬性,由小到大,升序對集合進行排序。

	@Test
	public void Stream_sorted_withComparing() {
		Fruit lichee = new Fruit("Lichee", -1, 3);
		Fruit coconut = new Fruit("Coconut", Double.MAX_VALUE, 1);
		Fruit plum = new Fruit("Plum", 3, 1);
		List<Fruit> list = new ArrayList<>(Arrays.asList(lichee, coconut, plum));
		System.out.println(list);

		ArrayList<Fruit> result = list.stream().sorted(Comparator.comparing(Fruit::getQuantity))
				.collect(Collectors.toCollection(ArrayList::new));
		System.out.println(result);
		assertThat(result).containsExactly(lichee, plum, coconut);
	}
[{"name":"Lichee","quantity":-1.0,"type":3}, {"name":"Coconut","quantity":1.7976931348623157E308,"type":1}, {"name":"Plum","quantity":3.0,"type":1}]
[{"name":"Lichee","quantity":-1.0,"type":3}, {"name":"Plum","quantity":3.0,"type":1}, {"name":"Coconut","quantity":1.7976931348623157E308,"type":1}]

SortListTest.java

Java Sort List with Examples 新增單元測試,驗證是否符合預期。

package org.ruoxue.java_147.list.sort;

import static org.assertj.core.api.Assertions.assertThat;

import java.util.ArrayList;
import java.util.Arrays;
import java.util.Collections;
import java.util.Comparator;
import java.util.List;
import java.util.stream.Collectors;

import org.apache.commons.lang3.builder.ToStringBuilder;
import org.apache.commons.lang3.builder.ToStringStyle;
import org.junit.Test;

import lombok.Builder;
import lombok.Getter;
import lombok.NoArgsConstructor;
import lombok.Setter;

public class SortListTest {

	@NoArgsConstructor
	@Getter
	@Setter
	@Builder
	public static class Fruit {

		private String name;
		private double quantity;
		private int type;

		public Fruit(String name, double quantity, int type) {
			this.name = name;
			this.quantity = quantity;
			this.type = type;
		}

		public String toString() {
			ToStringBuilder builder = new ToStringBuilder(this, ToStringStyle.JSON_STYLE);
			builder.appendSuper(super.toString());
			builder.append("name", name);
			builder.append("quantity", quantity);
			builder.append("type", type);
			return builder.toString();
		}
	}

	@Test
	public void Collections_sort() {
		List<String> list = Arrays.asList("Orange", "Mango", "Peach");
		System.out.println(list);

		Collections.sort(list);
		System.out.println(list);
		assertThat(list).containsExactly("Mango", "Orange", "Peach");
	}

	@Test
	public void Collections_sort_withComparator() {
		List<Double> list = Arrays.asList(Double.MAX_VALUE, -1d, 3d);
		System.out.println(list);

		Collections.sort(list, (i1, i2) -> Double.compare(i1, i2));
		System.out.println(list);
		assertThat(list).containsExactly(-1d, 3d, Double.MAX_VALUE);
	}

	@Test
	public void Collections_sort_withComparing() {
		Fruit orange = new Fruit("Orange", -1, 3);
		Fruit mango = new Fruit("Mango", Double.MAX_VALUE, 1);
		Fruit peach = new Fruit("Peach", 3, 1);
		List<Fruit> list = new ArrayList<>(Arrays.asList(orange, mango, peach));
		System.out.println(list);

		Collections.sort(list, Comparator.comparing(Fruit::getQuantity));
		System.out.println(list);
		assertThat(list).containsExactly(orange, peach, mango);
	}

	@Test
	public void List_sort() {
		List<String> list = Arrays.asList("Banana", "Apple", "Cherry");
		System.out.println(list);

		list.sort(null);
		System.out.println(list);
		assertThat(list).containsExactly("Apple", "Banana", "Cherry");
	}

	@Test
	public void List_sort_withComparator() {
		List<Double> list = Arrays.asList(Double.MAX_VALUE, -1d, 3d);
		System.out.println(list);

		list.sort((i1, i2) -> Double.compare(i1, i2));
		System.out.println(list);
		assertThat(list).containsExactly(-1d, 3d, Double.MAX_VALUE);
	}

	@Test
	public void List_sort_withComparing() {
		Fruit banana = new Fruit("Banana", -1, 3);
		Fruit apple = new Fruit("Apple", Double.MAX_VALUE, 1);
		Fruit cherry = new Fruit("Cherry", 3, 1);
		List<Fruit> list = new ArrayList<>(Arrays.asList(banana, apple, cherry));
		System.out.println(list);

		list.sort(Comparator.comparing(Fruit::getQuantity));
		System.out.println(list);
		assertThat(list).containsExactly(banana, cherry, apple);
	}

	@Test
	public void Stream_sorted() {
		List<String> list = Arrays.asList("Lichee", "Coconut", "Plum");
		System.out.println(list);

		ArrayList<String> result = list.stream().sorted().collect(Collectors.toCollection(ArrayList::new));
		System.out.println(result);
		assertThat(result).containsExactly("Coconut", "Lichee", "Plum");
	}

	@Test
	public void Stream_sorted_withComparator() {
		List<Double> list = Arrays.asList(Double.MAX_VALUE, -1d, 3d);
		System.out.println(list);

		ArrayList<Double> result = list.stream().sorted((i1, i2) -> Double.compare(i1, i2))
				.collect(Collectors.toCollection(ArrayList::new));
		System.out.println(result);
		assertThat(result).containsExactly(-1d, 3d, Double.MAX_VALUE);
	}

	@Test
	public void Stream_sorted_withComparing() {
		Fruit lichee = new Fruit("Lichee", -1, 3);
		Fruit coconut = new Fruit("Coconut", Double.MAX_VALUE, 1);
		Fruit plum = new Fruit("Plum", 3, 1);
		List<Fruit> list = new ArrayList<>(Arrays.asList(lichee, coconut, plum));
		System.out.println(list);

		ArrayList<Fruit> result = list.stream().sorted(Comparator.comparing(Fruit::getQuantity))
				.collect(Collectors.toCollection(ArrayList::new));
		System.out.println(result);
		assertThat(result).containsExactly(lichee, plum, coconut);
	}
}

心得分享

List Sort in Java 排序是指使用特定標準以特定順序排列資料,可以對不同類型的資料進行排序,像是字串、數字和物件,提供了幾種 Sort 常見方法的操作範例,在應用上相當廣泛,熟悉 Java Sort List with Examples 這些方法的操作,可以讓排序依照不同的需求,更簡易、快速地實現功能。

發佈留言