使用默认实现的NULL-SAFE映射比较器

发布于 2025-02-03 05:29:09 字数 1688 浏览 2 评论 0原文

是否有可能在Java 8中创建NULL-SAFE映射比较器而不编写自己的实现比较器

运行以下代码时,它会导致NPE,因为keyextractor concorpor.comparing()的参数可能返回null值:

public class ToSort
{

    private String sortBy;

    public ToSort(String sortBy)
    {
        this.sortBy = sortBy;
    }

    public String getSortBy()
    {
        return sortBy;
    }

    public static void main(String[] args)
    {
        // mapping comparator
        Comparator<ToSort> comp = Comparator.comparing(ToSort::getSortBy);                          
        SortedSet<ToSort> set = new TreeSet<>(comp);
        ToSort o1 = new ToSort("1");
        ToSort o2 = new ToSort(null);

        set.add(o1);

        System.out.println(set.contains(o2)); //NPE because o2.getSortBy() == null

    }
}

线程中的异常“ main” java.lang.nullpointerexception 在java.util.comparator.lambda $比较$ 77A9974F $ 1(comparator.java:469) 在java.util.com上 请访问java.util.com parator $ nullcomparator.compare(comparators.java:83) 在java.util.treemap.getentryusingcomparator(treemap.java:376) 在java.util.treemap.getentry(treemap.java:345) 在java.util.treemap.containskey(treemap.java:232) 在java.util.treeset.contains(treeet.java:234) 在test.tosort.main(tosort.java:48)

使用

Comparator<ToSort> comp = Comparator.nullsFirst(Comparator.comparing(ToSort::getSortBy));

也不起作用,因为tosortnull的对象。

我知道如何编写自己的比较器实现,我只是在搜索一个更“优雅”的解决方案

Comparator.comparingNullsFirst(ToSort::getSortBy)

Is there a build-in possibility to create a null-safe mapping comparator in Java 8 without writing a own implementation of Comparator?

When running the following code, it causes a NPE because the keyExtractor argument of Comparator.comparing() may return a null value:

public class ToSort
{

    private String sortBy;

    public ToSort(String sortBy)
    {
        this.sortBy = sortBy;
    }

    public String getSortBy()
    {
        return sortBy;
    }

    public static void main(String[] args)
    {
        // mapping comparator
        Comparator<ToSort> comp = Comparator.comparing(ToSort::getSortBy);                          
        SortedSet<ToSort> set = new TreeSet<>(comp);
        ToSort o1 = new ToSort("1");
        ToSort o2 = new ToSort(null);

        set.add(o1);

        System.out.println(set.contains(o2)); //NPE because o2.getSortBy() == null

    }
}

Exception in thread "main" java.lang.NullPointerException
at java.util.Comparator.lambda$comparing$77a9974f$1(Comparator.java:469)
at java.util.Comparator$$Lambda$2/1480010240.compare(Unknown Source)
at java.util.Comparators$NullComparator.compare(Comparators.java:83)
at java.util.TreeMap.getEntryUsingComparator(TreeMap.java:376)
at java.util.TreeMap.getEntry(TreeMap.java:345)
at java.util.TreeMap.containsKey(TreeMap.java:232)
at java.util.TreeSet.contains(TreeSet.java:234)
at test.ToSort.main(ToSort.java:48)

Using

Comparator<ToSort> comp = Comparator.nullsFirst(Comparator.comparing(ToSort::getSortBy));

does not work either as only ToSort objects that are null are treaded properly.

I know how to write my own Comparator implementation, I`m just searching a more "elegant" solution like

Comparator.comparingNullsFirst(ToSort::getSortBy)

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(2

紫轩蝶泪 2025-02-10 05:29:10

流的片段:

somePersonList
    .stream()
    .sorted(
        Comparator.comparing(SomePerson::getName,
        Comparator.nullsLast(String::compareTo))
    )
    .collect(Collectors.toList())

Snippet for streams:

somePersonList
    .stream()
    .sorted(
        Comparator.comparing(SomePerson::getName,
        Comparator.nullsLast(String::compareTo))
    )
    .collect(Collectors.toList())
花想c 2025-02-10 05:29:09

找到了一个可能的解决方案:

Comparator.comparing(ToSort::getSortBy, 
      Comparator.nullsFirst(Comparator.naturalOrder())
)

Found a possible solution:

Comparator.comparing(ToSort::getSortBy, 
      Comparator.nullsFirst(Comparator.naturalOrder())
)
~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文