V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
shiji
V2EX  ›  Java

求问 java8 排序 怎么简化代码

  •  
  •   shiji · 2021-07-27 22:57:47 +08:00 · 1941 次点击
    这是一个创建于 1233 天前的主题,其中的信息可能已经有所发展或是发生改变。
    给一个 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 条回复    2021-07-29 08:22:49 +08:00
    sunjiayao
        1
    sunjiayao  
       2021-07-27 23:04:01 +08:00
    Arrays.stream().sorted()
    6IbA2bj5ip3tK49j
        2
    6IbA2bj5ip3tK49j  
       2021-07-27 23:24:57 +08:00   ❤️ 1
    Arrays.stream(x).sorted(Comparator.comparing(o -> ((int[]) o)[0]).thenComparing(o -> ((int[]) o)[1]))
    aguesuka
        3
    aguesuka  
       2021-07-28 10:54:45 +08:00   ❤️ 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  
       2021-07-28 11:15:31 +08:00   ❤️ 1
    如果子数组的长度非固定或者非常长, 可以用 Java9 的 Arrays#compare(int[], int[]) , 它是根据 ArraysSupport#mismatch 实现的, 底层是 Unsafe 方法. 比自己写的 compare 好一些.
    shiji
        5
    shiji  
    OP
       2021-07-28 11:30:19 +08:00 via iPhone
    @aguesuka 谢谢大佬
    shiji
        6
    shiji  
    OP
       2021-07-29 08:22:49 +08:00
    说来惭愧,虽然泛型经常用,这么用的却是第一次见到
    关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   实用小工具   ·   3108 人在线   最高记录 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 25ms · UTC 04:48 · PVG 12:48 · LAX 20:48 · JFK 23:48
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.