guava的使用

对数组操作前判断是否会越界:

java 复制代码
        List<String> s = new ArrayList<>();
        System.out.println(Preconditions.checkElementIndex(2,s.size(),"下标长度超过了"));

是否为空

java 复制代码
        String s = null;
        System.out.println(Preconditions.checkNotNull(s));

判空和多个参数hashcode

java 复制代码
        String s = null;
        if (Objects.equal(null, s)) {
            System.out.println("为null");
            return;
        }
        //计算多个参数的hashcode
        int i = Objects.hashCode("123", "222");
        System.out.println(i);
java 复制代码
      Ordering<Comparable> natural = Ordering.natural();
        List<LocalDateTime> list = new ArrayList<>(Arrays.asList(LocalDateTime.parse("2022-11-12T10:20:30"), LocalDateTime.parse("2021-11-12T10:20:21"), LocalDateTime.parse("2021-11-12T10:21:30")));
        list.sort(natural);
        list.stream().forEach(e -> {
            System.out.println(e);
        });

上面的:

复制代码
 Ordering.natural()

就是获取一个默认的排序(能够支持排序的类,都会实现比较器的方法,也就是说默认使用该类实现的比较方法)。

复制代码
 Ordering.natural().reverse();

reverse就是相反的意思,取相反的排序规则。

就是创建了一个反序排序类,它也实现了比较方法,但是参数的比较顺序改变了。然后返回:

排序遇到null放在最后和排序遇到null放在最前:

复制代码
Ordering<Comparable> natural = Ordering.natural().nullsLast();
复制代码
Ordering<Comparable> natural = Ordering.natural().nullsFirst();

就是判断带比较的数据,如果为null,就返回相应的数字

比较器只有三种情况:

1、左边比右边大,正数。

2、一样大,零。

3、最左边比右边小,负数。

合并排序器:

这个就挺有意思的了,也是换一个类返回来,这个类里有一个方法,当比较时发生相等时,就调用便利一个集合里的比较器方法:

也就是说可以把多个判断让在这里面,前提时上一个比较方法发生了相等。

java 复制代码
//UsetTest中默认有一个升序name的比较器 
//    @Override
//    public int compare(UserTest o1, UserTest o2) {
//        return o1.getName().compareTo(o2.getName());
//    }
       
Ordering<UserTest> from = Ordering.from(new UserTest()).compound(new Comparator<UserTest>() {
            @Override
            public int compare(UserTest o1, UserTest o2) {
                return o2.getAge() - o1.age;
            }
        });
        List<UserTest> list = new ArrayList<>(Arrays.asList(new UserTest("1", 1), new UserTest("2", 2), new UserTest("1", 2)));
        list.sort(from);
        list.stream().forEach(e -> {
            System.out.println(e);
        });
相关推荐
橙子家9 小时前
浏览器缓存之【基础键值存储】:Local storage 和 Session storage
前端
星星在线11 小时前
MusicFree:一个「All in One」的个人音乐服务器,让听歌回归简单
前端·后端
IT_陈寒12 小时前
Redis的SETNX并发问题让我加了三天班
前端·人工智能·后端
demo007x12 小时前
Docling 文档转换以及技术架构分析
前端·后端·程序员
京东云开发者13 小时前
京东市民服务又“上新”!这次是黑龙江“龙易办”
前端
NE_STOP14 小时前
Vide Coding--AI编程工具的选择
java
袋鱼不重14 小时前
我的神奇同事,AI 用多了居然写了个 Open In Codex
前端·后端·ai编程
码云数智-园园14 小时前
C++20 Modules 模块详解
java·开发语言·spring
Fireworks14 小时前
深入vue3源码解读 -- 1、响应式的基础概念
前端
程序员黑豆14 小时前
JDK 下载安装与配置详细教程
java·前端·ai编程