shiji
V2EX  ›  Java

求问 java8 排序 怎么简化代码

  •  
  •   shiji · Jul 27, 2021 · 2426 views
    This topic created in 1753 days ago, the information mentioned may be changed or developed.
    给一个 2d array: int [][]
    它的子数组的长度固定为 2.
    {
    {1,3},
    {1,4},
    {2,3},
    .....
    }

    比较的方法是先比子数组的第一个数,如果一样的话再比较第二个数字。

    想知道怎么用 lambda 或者 Comparator.comparing(xxx).thenComparing(xxx) 这样的方式简短的写出来?

    如果是个 Object, 可以用 Comparator.comparing(Person::getAge).thenComparing(Person::getScore)这种方式,换成是 Array 不知道该怎么办了。

    谢谢
    6 replies    2021-07-29 08:22:49 +08:00
    luman
        1
    luman  
       Jul 27, 2021
    Arrays.stream().sorted()
    6IbA2bj5ip3tK49j
        2
    6IbA2bj5ip3tK49j  
       Jul 27, 2021   ❤️ 1
    Arrays.stream(x).sorted(Comparator.comparing(o -> ((int[]) o)[0]).thenComparing(o -> ((int[]) o)[1]))
    aguesuka
        3
    aguesuka  
       Jul 28, 2021   ❤️ 1
    Arrays.sort(array, Comparator.<int[]>comparingInt(arr -> arr[0])
    .thenComparingInt(arr -> arr[1]));

    3 个细节.
    原地排序不需要使用 stream.
    使用 comparingInt 而不是 comparing.
    为 comparingInt 显示声明泛型参数<int[]> 而不是在 lambda 中 cast
    aguesuka
        4
    aguesuka  
       Jul 28, 2021   ❤️ 1
    如果子数组的长度非固定或者非常长, 可以用 Java9 的 Arrays#compare(int[], int[]) , 它是根据 ArraysSupport#mismatch 实现的, 底层是 Unsafe 方法. 比自己写的 compare 好一些.
    shiji
        5
    shiji  
    OP
       Jul 28, 2021 via iPhone
    @aguesuka 谢谢大佬
    shiji
        6
    shiji  
    OP
       Jul 29, 2021
    说来惭愧,虽然泛型经常用,这么用的却是第一次见到
    About   ·   Help   ·   Advertise   ·   Blog   ·   API   ·   FAQ   ·   Solana   ·   2973 Online   Highest 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 34ms · UTC 09:32 · PVG 17:32 · LAX 02:32 · JFK 05:32
    ♥ Do have faith in what you're doing.