不要再重复造轮子了!这17个Java常用工具类,让生产力爆表

不要再重复造轮子了!这17个Java常用工具类,让生产力爆表

前言

  • 在java的庞大体系中,其实有很多不错的小工具,也就是我们平常说的:轮子
  • 如果在我们的日常工作当中,能够将这些轮子用户,再配合一下idea的快捷键,可以极大得提升我们的开发效率。
  • 今天我决定把一些压箱底的小工具,分享给大家,希望对你有所帮助。
  • 本文会分享17个我们日常工作中一定会用得到的小工具,主要内容如下:

Collections

  • 首先出场的是java.util包下的Collections类,该类主要用于操作集合或者返回集合,我个人非常喜欢用它。

排序

  • 在工作中经常有对集合排序的需求。

  • 看看使用Collections工具是如何实现升序和降序的:

  • List<Integer> list = new ArrayList<>();
      list.add(2);
      list.add(1);
      list.add(3);
      Collections.sort(list);//升序
      System.out.println(list);
      Collections.reverse(list);//降序
      System.out.println(list);
    
  • 执行结果:

  • [1, 2, 3]
    [3, 2, 1]
    

获取最大或最小值

  • 有时候需要找出集合中的最大值或者最小值,这时可以使用Collections的maxmin方法。例如:

  • List<Integer> list = new ArrayList<>();
    list.add(2);
    list.add(1);
    list.add(3);
    Integer max = Collections.max(list);//获取最大值
    Integer min = Collections.min(list);//获取最小值
    System.out.println(max);
    System.out.println(min);
    
  • 执行结果:

  • 3
    1
    

转换线程安全集合

  • 我们都知道,java中的很多集合,比如:ArrayList、LinkedList、HashMap、HashSet等,都是线程不安全的。

  • 换句话说,这些集合在多线程的环境中,添加数据会出现异常。

  • 这时,可以用Collections的synchronizedxxx方法,将这些线程不安全的集合,直接转换成线程安全集合。例如:

  •  List<Integer> list = new ArrayList<>();
      list.add(2);
      list.add(1);
      list.add(3);
    
      List<Integer> integers = Collections.synchronizedList(list);//将ArrayList转换成线程安全集合
      System.out.println(integers);
    
  • 它的底层会创建SynchronizedRandomAccessList或者SynchronizedList类,这两个类的很多方法都会用synchronized加锁。

返回空集合

  • 有时,我们在判空之后,需要返回空集合,就可以使用emptyList方法,例如:

  • private List<Integer> fun(List<Integer> list) {
        if (list == null || list.size() == 0) {
            return Collections.emptyList();
        }
        //业务处理
        return list;
    }
    

二分查找

  • binarySearch方法提供了一个非常好用的二分查找功能,只用传入指定集合和需要找到的key即可。例如:

  • List<Integer> list = new ArrayList<>();
    list.add(2);
    list.add(1);
    list.add(3);
    
    int i = Collections.binarySearch(list, 3);//二分查找
    System.out.println(i );
    
  • 执行结果:

  • 2
    

转换成不可修改集合

  • 为了防止后续的程序把某个集合的结果修改了,有时候我们需要把某个集合定义成不可修改的,使用Collections的unmodifiablexxx方法就能轻松实现:

  • List<Integer> list = new ArrayList<>();
    list.add(2);
    list.add(1);
    list.add(3);
    
    List<Integer> integers = Collections.unmodifiableList(list);
    integers.add(4);
    System.out.println(integers);
    
  • 执行结果:

  • Exception in thread "main" java.lang.UnsupportedOperationException
     at java.util.Collections$UnmodifiableCollection.add(Collections.java:1055)
     at com.sue.jump.service.test1.UtilTest.main(UtilTest.java:19)
    
  • 当然Collections工具类中还有很多常用的方法,在这里就不一一介绍了,需要你自己去探索。

  • 在这里插入图片描述

  • 在这里插入图片描述

CollectionUtils

  • 对集合操作,除了前面说的Collections工具类之后,CollectionUtils工具类也非常常用。

  • 目前比较主流的是springorg.springframework.util包下的CollectionUtils工具类。

  • 在这里插入图片描述

  • apacheorg.apache.commons.collections包下的CollectionUtils工具类。

  • 在这里插入图片描述

  • 我个人更推荐使用apache的包下的CollectionUtils工具类,因为它的工具更多更全面。

  • 举个简单的例子,spring的CollectionUtils工具类没有判断集合不为空的方法。而apache的CollectionUtils工具类却有。

  • 下面我们以apache的CollectionUtils工具类为例,介绍一下常用方法。

集合判空

  • 通过CollectionUtils工具类的isEmpty方法可以轻松判断集合是否为空,isNotEmpty方法判断集合不为空。

  • List<Integer> list = new ArrayList<>();
    list.add(2);
    list.add(1);
    list.add(3);
    
    if (CollectionUtils.isEmpty(list)) {
        System.out.println("集合为空");
    }
    
    if (CollectionUtils.isNotEmpty(list)) {
        System.out.println("集合不为空");
    }
    

对两个集合进行操作

  • 有时候我们需要对已有的两个集合进行操作,比如取交集或者并集等。

  • List<Integer> list = new ArrayList<>();
    list.add(2);
    list.add(1);
    list.add(3);
    
    List<Integer> list2 = new ArrayList<>();
    list2.add(2);
    list2.add(4);
    
    //获取并集
    Collection<Integer> unionList = CollectionUtils.union(list, list2);
    System.out.println(unionList);
    
    //获取交集
    Collection<Integer> intersectionList = CollectionUtils.intersection(list, list2);
    System.out.println(intersectionList);
    
    //获取交集的补集
    Collection<Integer> disjunctionList = CollectionUtils.disjunction(list, list2);
    System.out.println(disjunctionList);
    
    //获取差集
    Collection<Integer> subtractList = CollectionUtils.subtract(list, list2);
    System.out.println(subtractList);
    
  • 执行结果:

  • [1, 2, 3, 4]
    [2]
    [1, 3, 4]
    [1, 3]
    
  • 说句实话,对两个集合的操作,在实际工作中用得挺多的,特别是很多批量的场景中。以前我们需要写一堆代码,但没想到有现成的轮子。

Lists

  • 如果你引入com.google.guava的pom文件,会获得很多好用的小工具。这里推荐一款com.google.common.collect包下的集合工具:Lists
  • 它是在太好用了,让我爱不释手。

创建空集合

  • 有时候,我们想创建一个空集合。这时可以用Lists的newArrayList方法,例如:

  • List<Integer> list = Lists.newArrayList();
    

快速初始化集合

  • 有时候,我们想给一个集合中初始化一些元素。这时可以用Lists的newArrayList方法,例如:

  • List<Integer> list = Lists.newArrayList(1, 2, 3);
    
  • 执行结果:

  • [1, 2, 3]
    

笛卡尔积

  • 如果你想将两个集合做笛卡尔积,Lists的cartesianProduct方法可以帮你实现:

  • List<Integer> list1 = Lists.newArrayList(1, 2, 3);
    List<Integer> list2 = Lists.newArrayList(4,5);
    List<List<Integer>> productList = Lists.cartesianProduct(list1,list2);
    System.out.println(productList);
    
  • 执行结果:

  • [[1, 4], [1, 5], [2, 4], [2, 5], [3, 4], [3, 5]]
    

分页

  • 如果你想将一个大集合分成若干个小集合,可以使用Lists的partition方法:

  • List<Integer> list = Lists.newArrayList(1, 2, 3, 4, 5);
    List<List<Integer>> partitionList = Lists.partition(list, 2);
    System.out.println(partitionList);
    
  • 执行结果:

  • [[1, 2], [3, 4], [5]]
    
  • 这个例子中,list有5条数据,我将list集合按大小为2,分成了3页,即变成3个小集合。

  • 这个是我最喜欢的方法之一,经常在项目中使用。

  • 比如有个需求:现在有5000个id,需要调用批量用户查询接口,查出用户数据。但如果你直接查5000个用户,单次接口响应时间可能会非常慢。如果改成分页处理,每次只查500个用户,异步调用10次接口,就不会有单次接口响应慢的问题。

流处理

  • 如果我们想把某个集合转换成另外一个接口,可以使用Lists的transform方法。例如:

  • List<String> list = Lists.newArrayList("a","b","c");
    List<String> transformList = Lists.transform(list, x -> x.toUpperCase());
    System.out.println(transformList);
    
  • 将小写字母转换成了大写字母。

颠倒顺序

  • Lists的有颠倒顺序的方法reverse。例如:

  • List<Integer> list = Lists.newArrayList(3, 1, 2);
    List<Integer> reverseList = Lists.reverse(list);
    System.out.println(reverseList);
    
  • 执行结果:

  • [2, 1, 3]
    
  • list的原始顺序是312,使用reverse方法颠倒顺序之后,变成了213。

  • Lists还有其他的好用的工具,我在这里只是抛砖引玉,有兴趣的朋友,可以仔细研究一下。

  • 在这里插入图片描述

Objects

  • jdk7之后,提供了Objects工具类,我们可以通过它操作对象。

对象判空

  • 在java中万事万物皆对象,对象的判空可以说无处不在。Objects的isNull方法判断对象是否为空,而nonNull方法判断对象是否不为空。例如:

  • Integer integer = new Integer(1);
    
    if (Objects.isNull(integer)) {
        System.out.println("对象为空");
    }
    
    if (Objects.nonNull(integer)) {
        System.out.println("对象不为空");
    }
    

对象为空抛异常

  • 如果我们想在对象为空时,抛出空指针异常,可以使用Objects的requireNonNull方法。例如:

  • Integer integer1 = new Integer(128);
    
    Objects.requireNonNull(integer1);
    Objects.requireNonNull(integer1, "参数不能为空");
    Objects.requireNonNull(integer1, () -> "参数不能为空");
    

判断两个对象是否相等

  • 我们经常需要判断两个对象是否相等,Objects给我们提供了equals方法,能非常方便的实现:

  • Integer integer1 = new Integer(1);
    Integer integer2 = new Integer(1);
    
    System.out.println(Objects.equals(integer1, integer2));
    
  • 执行结果:

  • true
    
  • 但使用这个方法有坑,比如例子改成:

  • Integer integer1 = new Integer(1);
    Long integer2 = new Long(1);
    
    System.out.println(Objects.equals(integer1, integer2));
    
  • 执行结果:

  • false
    

获取对象的hashCode

  • 如果你想获取某个对象的hashCode,可以使用Objects的hashCode方法。例如:

  • String str = new String("abc");
    System.out.println(Objects.hashCode(str));
    
  • 执行结果:

  • 96354
    
  • Objects的内容先介绍到这里,有兴趣的小伙们,可以看看下面更多的方法:

  • 在这里插入图片描述

BooleanUtils

  • 在java中布尔值,随处可见。
  • 如果你使用了布尔的包装类:Boolean,总感觉有点麻烦,因为它有三种值:nulltruefalse。我们在处理Boolean对象时,需要经常判空。
  • 头疼!!!
  • 但如果使用BooleanUtils类处理布尔值,心情一下子就愉悦起来了。

判断true或false

  • 如果你想判断某个参数的值是true或false,可以直接使用isTrueisFalse方法。例如:

  • Boolean aBoolean = new Boolean(true);
    System.out.println(BooleanUtils.isTrue(aBoolean));
    System.out.println(BooleanUtils.isFalse(aBoolean));
    

判断不为true或不为false

  • 有时候,需要判断某个参数不为true,即是null或者false。或者判断不为false,即是null或者true。

  • 可以使用isNotTrueisNotFalse方法。例如:

  • Boolean aBoolean = new Boolean(true);
    Boolean aBoolean1 = null;
    System.out.println(BooleanUtils.isNotTrue(aBoolean));
    System.out.println(BooleanUtils.isNotTrue(aBoolean1));
    System.out.println(BooleanUtils.isNotFalse(aBoolean));
    System.out.println(BooleanUtils.isNotFalse(aBoolean1));
    
  • 执行结果:

  • false
    true
    true
    true
    

转换成数字

  • 如果你想将true转换成数字1,false转换成数字0,可以使用toInteger方法:

  • Boolean aBoolean = new Boolean(true);
    Boolean aBoolean1 = new Boolean(false);
    System.out.println(BooleanUtils.toInteger(aBoolean));
    System.out.println(BooleanUtils.toInteger(aBoolean1));
    
  • 执行结果:

  • 1
    0
    

Boolean转换成布尔值

  • 我们有时候需要将包装类Boolean对象,转换成原始的boolean对象,可以使用toBoolean方法。例如:

  • Boolean aBoolean = new Boolean(true);
    Boolean aBoolean1 = null;
    System.out.println(BooleanUtils.toBoolean(aBoolean));
    System.out.println(BooleanUtils.toBoolean(aBoolean1));
    System.out.println(BooleanUtils.toBooleanDefaultIfNull(aBoolean1, false));
    
  • 我们无需额外的判空了,而且还可以设置Boolean对象为空时返回的默认值。

  • BooleanUtils类的方法还有很多,有兴趣的小伙伴可以看看下面的内容:

  • 在这里插入图片描述

StringUtils

  • 字符串(String)在我们的日常工作中,用得非常非常非常多。
  • 在我们的代码中经常需要对字符串判空,截取字符串、转换大小写、分隔字符串、比较字符串、去掉多余空格、拼接字符串、使用正则表达式等等。
  • 如果只用String类提供的那些方法,我们需要手写大量的额外代码,不然容易出现各种异常。
  • 现在有个好消息是:org.apache.commons.lang3包下的StringUtils工具类,给我们提供了非常丰富的选择。

字符串判空

  • 其实空字符串,不只是null一种,还有"“,” ","null"等等,多种情况。

  • StringUtils给我们提供了多个判空的静态方法,例如:

  • String str1 = null;
    String str2 = "";
    String str3 = " ";
    String str4 = "abc";
    System.out.println(StringUtils.isEmpty(str1));
    System.out.println(StringUtils.isEmpty(str2));
    System.out.println(StringUtils.isEmpty(str3));
    System.out.println(StringUtils.isEmpty(str4));
    System.out.println("=====");
    System.out.println(StringUtils.isNotEmpty(str1));
    System.out.println(StringUtils.isNotEmpty(str2));
    System.out.println(StringUtils.isNotEmpty(str3));
    System.out.println(StringUtils.isNotEmpty(str4));
    System.out.println("=====");
    System.out.println(StringUtils.isBlank(str1));
    System.out.println(StringUtils.isBlank(str2));
    System.out.println(StringUtils.isBlank(str3));
    System.out.println(StringUtils.isBlank(str4));
    System.out.println("=====");
    System.out.println(StringUtils.isNotBlank(str1));
    System.out.println(StringUtils.isNotBlank(str2));
    System.out.println(StringUtils.isNotBlank(str3));
    System.out.println(StringUtils.isNotBlank(str4));
    
  • 执行结果:

  • true
    true
    false
    false
    =====
    false
    false
    true
    true
    =====
    true
    true
    true
    false
    =====
    false
    false
    false
    true
    
  • 示例中的:isEmptyisNotEmptyisBlankisNotBlank,这4个判空方法你们可以根据实际情况使用。

  • 优先推荐使用isBlankisNotBlank方法,因为它会把" "也考虑进去。

分隔字符串

  • 分隔字符串是常见需求,如果直接使用String类的split方法,就可能会出现空指针异常。

  • String str1 = null;
    System.out.println(StringUtils.split(str1,","));
    System.out.println(str1.split(","));
    
  • 执行结果:

  • null
    Exception in thread "main" java.lang.NullPointerException
     at com.sue.jump.service.test1.UtilTest.main(UtilTest.java:21)
    
  • 使用StringUtils的split方法会返回null,而使用String的split方法会报指针异常。

判断是否纯数字

  • 给定一个字符串,判断它是否为纯数字,可以使用isNumeric方法。例如:

  • String str1 = "123";
    String str2 = "123q";
    String str3 = "0.33";
    System.out.println(StringUtils.isNumeric(str1));
    System.out.println(StringUtils.isNumeric(str2));
    System.out.println(StringUtils.isNumeric(str3));
    
  • 执行结果:

  • true
    false
    false
    

将集合拼接成字符串

  • 有时候,我们需要将某个集合的内容,拼接成一个字符串,然后输出,这时可以使用join方法。例如:

  • List<String> list = Lists.newArrayList("a", "b", "c");
    List<Integer> list2 = Lists.newArrayList(1, 2, 3);
    System.out.println(StringUtils.join(list, ","));
    System.out.println(StringUtils.join(list2, " "));
    
  • 执行结果:

  • a,b,c
    1 2 3
    
  • 当然还有很多实用的方法,我在这里就不一一介绍了。

  • 在这里插入图片描述

  • 在这里插入图片描述

Assert

  • 很多时候,我们需要在代码中做判断:如果不满足条件,则抛异常。
  • 有没有统一的封装呢?
  • 其实spring给我们提供了Assert类,它表示断言

断言参数是否为空

  • 断言参数是否空,如果不满足条件,则直接抛异常。

  • String str = null;
    Assert.isNull(str, "str必须为空");
    Assert.isNull(str, () -> "str必须为空");
    Assert.notNull(str, "str不能为空");
    
  • 如果不满足条件就会抛出IllegalArgumentException异常。

断言集合是否为空

  • 断言集合是否空,如果不满足条件,则直接抛异常。

  • List<String> list = null;
    Map<String, String> map = null;
    Assert.notEmpty(list, "list不能为空");
    Assert.notEmpty(list, () -> "list不能为空");
    Assert.notEmpty(map, "map不能为空");
    
  • 如果不满足条件就会抛出IllegalArgumentException异常。

断言条件是否为空

  • 断言是否满足某个条件,如果不满足条件,则直接抛异常。

  • List<String> list = null;
    Assert.isTrue(CollectionUtils.isNotEmpty(list), "list不能为空");
    Assert.isTrue(CollectionUtils.isNotEmpty(list), () -> "list不能为空");
    
  • 当然Assert类还有一些其他的功能,这里就不多介绍了。

  • 在这里插入图片描述

IOUtils

  • IO流在我们日常工作中也用得比较多,尽管java已经给我们提供了丰富的API。
  • 但我们不得不每次读取文件,或者写入文件之后,写一些重复的的代码。手动在finally代码块中关闭流,不然可能会造成内存溢出
  • 有个好消息是:如果你使用org.apache.commons.io包下的IOUtils类,会节省大量的时间。

读取文件

  • IO流在我们日常工作中也用得比较多,尽管java已经给我们提供了丰富的API。
  • 但我们不得不每次读取文件,或者写入文件之后,写一些重复的的代码。手动在finally代码块中关闭流,不然可能会造成内存溢出
  • 有个好消息是:如果你使用org.apache.commons.io包下的IOUtils类,会节省大量的时间。

读取文件

  • 如果你想将某个txt文件中的数据,读取到字符串当中,可以使用IOUtils类的toString方法。例如:

  • String str = IOUtils.toString(new FileInputStream("/temp/a.txt"), StandardCharsets.UTF_8);
    System.out.println(str);
    

写入文件

  • 如果你想将某个字符串的内容,写入到指定文件当中,可以使用IOUtils类的write方法。例如:

  • String str = "abcde";
    IOUtils.write(str, new FileOutputStream("/temp/b.tx"), StandardCharsets.UTF_8);
    

文件拷贝

  • 如果你想将某个文件中的所有内容,都拷贝到另一个文件当中,可以使用IOUtils类的copy方法。例如:

  • IOUtils.copy(new FileInputStream("/temp/a.txt"), new FileOutputStream("/temp/b.txt"));
    

读取文件内容到字节数组

  • 如果你想将某个文件中的内容,读取字节数组中,可以使用IOUtils类的toByteArray方法。例如:

  • byte[] bytes = IOUtils.toByteArray(new FileInputStream("/temp/a.txt"));
    
  • IOUtils类非常实用,感兴趣的小伙们,可以看看下面内容。

  • 在这里插入图片描述

MDC

  • MDCorg.slf4j包下的一个类,它的全称是Mapped Diagnostic Context,我们可以认为它是一个线程安全的存放诊断日志的容器。

  • MDC的底层是用了ThreadLocal来保存数据的。

  • 我们可以用它传递参数。

  • 例如现在有这样一种场景:我们使用RestTemplate调用远程接口时,有时需要在header中传递信息,比如:traceId,source等,便于在查询日志时能够串联一次完整的请求链路,快速定位问题。

  • 这种业务场景就能通过ClientHttpRequestInterceptor接口实现,具体做法如下:

  • 第一步,定义一个LogFilter拦截所有接口请求,在MDC中设置traceId:

  • public class LogFilter implements Filter {
        @Override
        public void init(FilterConfig filterConfig) throws ServletException {
        }
    
        @Override
        public void doFilter(ServletRequest request, ServletResponse response, FilterChain chain) throws IOException, ServletException {
            MdcUtil.add(UUID.randomUUID().toString());
            System.out.println("记录请求日志");
            chain.doFilter(request, response);
            System.out.println("记录响应日志");
        }
    
        @Override
        public void destroy() {
        }
    }
    
  • 第二步,实现ClientHttpRequestInterceptor接口,MDC中获取当前请求的traceId,然后设置到header中:

  • public class RestTemplateInterceptor implements ClientHttpRequestInterceptor {
    
        @Override
        public ClientHttpResponse intercept(HttpRequest request, byte[] body, ClientHttpRequestExecution execution) throws IOException {
            request.getHeaders().set("traceId", MdcUtil.get());
            return execution.execute(request, body);
        }
    }
    
  • 第三步,定义配置类,配置上面定义的RestTemplateInterceptor类:

  • @Configuration
    public class RestTemplateConfiguration {
    
        @Bean
        public RestTemplate restTemplate() {
            RestTemplate restTemplate = new RestTemplate();
            restTemplate.setInterceptors(Collections.singletonList(restTemplateInterceptor()));
            return restTemplate;
        }
    
        @Bean
        public RestTemplateInterceptor restTemplateInterceptor() {
            return new RestTemplateInterceptor();
        }
    }
    
  • 其中MdcUtil其实是利用MDC工具在ThreadLocal中存储和获取traceId

  • public class MdcUtil {
    
        private static final String TRACE_ID = "TRACE_ID";
    
        public static String get() {
            return MDC.get(TRACE_ID);
        }
    
        public static void add(String value) {
            MDC.put(TRACE_ID, value);
        }
    }
    
  • 当然,这个例子中没有演示MdcUtil类的add方法具体调的地方,我们可以在filter中执行接口方法之前,生成traceId,调用MdcUtil类的add方法添加到MDC中,然后在同一个请求的其他地方就能通过MdcUtil类的get方法获取到该traceId。

  • 能使用MDC保存traceId等参数的根本原因是,用户请求到应用服务器,Tomcat会从线程池中分配一个线程去处理该请求。

  • 那么该请求的整个过程中,保存到MDC的ThreadLocal中的参数,也是该线程独享的,所以不会有线程安全问题。

ClassUtils

  • spring的org.springframework.util包下的ClassUtils类,它里面有很多让我们惊喜的功能。
  • 它里面包含了类和对象相关的很多非常实用的方法。

获取对象的所有接口

  • 如果你想获取某个对象的所有接口,可以使用ClassUtils的getAllInterfaces方法。例如:

  • Class<?>[] allInterfaces = ClassUtils.getAllInterfaces(new User());
    

获取某个类的包名

  • 如果你想获取某个类的包名,可以使用ClassUtils的getPackageName方法。例如:

  • String packageName = ClassUtils.getPackageName(User.class);
    System.out.println(packageName);
    

判断某个类是否内部类

  • 如果你想判断某个类是否内部类,可以使用ClassUtils的isInnerClass方法。例如:

  • System.out.println(ClassUtils.isInnerClass(User.class));
    

判断对象是否代理对象

  • 如果你想判断对象是否代理对象,可以使用ClassUtils的isCglibProxy方法。例如:

  • System.out.println(ClassUtils.isCglibProxy(new User()));
    
  • ClassUtils还有很多有用的方法,等待着你去发掘。感兴趣的朋友,可以看看下面内容:

  • 在这里插入图片描述

BeanUtils

  • spring给我们提供了一个JavaBean的工具类,它在org.springframework.beans包下面,它的名字叫做:BeanUtils
  • 让我们一起看看这个工具可以带给我们哪些惊喜。

拷贝对象的属性

  • 曾几何时,你有没有这样的需求:把某个对象中的所有属性,都拷贝到另外一个对象中。这时就能使用BeanUtils的copyProperties方法。例如:

  • User user1 = new User();
    user1.setId(1L);
    user1.setName("苏三说技术");
    user1.setAddress("成都");
    
    User user2 = new User();
    BeanUtils.copyProperties(user1, user2);
    System.out.println(user2);
    

实例化某个类

  • 如果你想通过反射实例化一个类的对象,可以使用BeanUtils的instantiateClass方法。例如:

  • User user = BeanUtils.instantiateClass(User.class);
    System.out.println(user);
    

获取指定类的指定方法

  • 如果你想获取某个类的指定方法,可以使用BeanUtils的findDeclaredMethod方法。例如:

  • Method declaredMethod = BeanUtils.findDeclaredMethod(User.class, "getId");
    System.out.println(declaredMethod.getName());
    
  • 如果你对BeanUtils比较感兴趣,可以看看下面内容:

  • 在这里插入图片描述

ReflectionUtils

  • 有时候,我们需要在项目中使用反射功能,如果使用最原始的方法来开发,代码量会非常多,而且很麻烦,它需要处理一大堆异常以及访问权限等问题。
  • 好消息是spring给我们提供了一个ReflectionUtils工具,它在org.springframework.util包下面。

获取方法

  • 如果你想获取某个类的某个方法,可以使用ReflectionUtils类的findMethod方法。例如:

  • Method method = ReflectionUtils.findMethod(User.class, "getId");
    

获取字段

  • 如果你想获取某个类的某个字段,可以使用ReflectionUtils类的findField方法。例如:

  • Field field = ReflectionUtils.findField(User.class, "id");
    

执行方法

  • 如果你想通过反射调用某个方法,传递参数,可以使用ReflectionUtils类的invokeMethod方法。例如:

  • ReflectionUtils.invokeMethod(method, springContextsUtil.getBean(beanName), param);
    

判断字段是否常量

  • 如果你想判断某个字段是否常量,可以使用ReflectionUtils类的isPublicStaticFinal方法。例如:

  • Field field = ReflectionUtils.findField(User.class, "id");
    System.out.println(ReflectionUtils.isPublicStaticFinal(field));
    

判断是否equals方法

  • 如果你想判断某个方法是否equals方法,可以使用ReflectionUtils类的isEqualsMethod方法。例如:

  • Method method = ReflectionUtils.findMethod(User.class, "getId");
    System.out.println(ReflectionUtils.isEqualsMethod(method));
    
  • 当然这个类还有不少有趣的方法,感兴趣的朋友,可以看看下面内容:

在这里插入图片描述

Base64Utils

  • 有时候,为了安全考虑,需要将参数只用base64编码。

  • 这时就能直接使用org.springframework.util包下的Base64Utils工具类。

  • 它里面包含:encodedecode方法,用于对数据进行加密和解密。例如:

  • String str = "abc";
    String encode = new String(Base64Utils.encode(str.getBytes()));
    System.out.println("加密后:" + encode);
    try {
        String decode = new String(Base64Utils.decode(encode.getBytes()), "utf8");
        System.out.println("解密后:" + decode);
    } catch (UnsupportedEncodingException e) {
        e.printStackTrace();
    }
    
  • 执行结果:

  • 加密后:YWJj
    解密后:abc
    

StandardCharsets

  • 我们在做字符转换的时候,经常需要指定字符编码,比如:UTF-8、ISO-8859-1等等。

  • 这时就可以直接使用java.nio.charset包下的StandardCharsets类中静态变量。

  • 例如:

  • String str = "abc";
    String encode = new String(Base64Utils.encode(str.getBytes()));
    System.out.println("加密后:" + encode);
    String decode = new String(Base64Utils.decode(encode.getBytes())
    , StandardCharsets.UTF_8);
    System.out.println("解密后:" + decode);
    

DigestUtils

  • 有时候,我们需要对数据进行加密处理,比如:md5或sha256。
  • 可以使用apache的org.apache.commons.codec.digest包下的DigestUtils类。

md5加密

  • 如果你想对数据进行md5加密,可以使用DigestUtils的md5Hex方法。例如:

  • String md5Hex = DigestUtils.md5Hex("苏三说技术");
    System.out.println(md5Hex);
    

sha256加密

  • 如果你想对数据进行sha256加密,可以使用DigestUtils的sha256Hex方法。例如:

  • String md5Hex = DigestUtils.sha256Hex("苏三说技术");
    System.out.println(md5Hex);
    
  • 当然这个工具还有很多其他的加密方法:

  • 在这里插入图片描述

SerializationUtils

  • 有时候,我们需要把数据进行序列化反序列化处理。

  • 传统的做法是某个类实现Serializable接口,然后重新它的writeObjectreadObject方法。

  • 但如果使用org.springframework.util包下的SerializationUtils工具类,能更轻松实现序列化和反序列化功能。例如:

  • Map<String, String> map = Maps.newHashMap();
    map.put("a", "1");
    map.put("b", "2");
    map.put("c", "3");
    byte[] serialize = SerializationUtils.serialize(map);
    Object deserialize = SerializationUtils.deserialize(serialize);
    System.out.println(deserialize);
    

HttpStatus

  • 很多时候,我们会在代码中定义http的返回码,比如:接口正常返回200,异常返回500,接口找不到返回404,接口不可用返回502等。

  • private int SUCCESS_CODE = 200;
    private int ERROR_CODE = 500;
    private int NOT_FOUND_CODE = 404;
    
  • 其实org.springframework.http包下的HttpStatus枚举,或者org.apache.http包下的HttpStatus接口,已经把常用的http返回码给我们定义好了,直接拿来用就可以了,真的不用再重复定义了。

  • 在这里插入图片描述

  • 5
    点赞
  • 10
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 1
    评论
### 回答1: Java实用代码是一种能够提高Java开发效率的宝贵资源。500套java实用代码包括了Java博客项目、工具类和小程序。这些代码能够帮助开发人员解决常见的问题,并提供了一些可靠的解决方案。 Java博客项目包括了一套完整的代码,可以用于构建个人或团队的博客网站。它提供了用户管理、文章发布和评论等功能,并且具备良好的安全性和稳定性。通过使用这个项目,开发人员可以节省大量的开发时间,专注于博客网站的业务逻辑和用户体验的提升。 工具类Java开发中常用的一种实用代码。它是一组静态方法的集合,提供了许多常见的功能和操作的实现。例如,日期处理、字符串操作、文件读写和加密解密等。开发人员可以通过使用这些工具类,快速完成一些常见的工作,避免重复轮子,提高了代码的可维护性和可读性。 小程序是一种独立运行的Java代码段,用于解决特定的问题。它可以用于实现一些单一的功能,如文件上传、数据备份和网络请求等。小程序一般都比较简单,但是对于特定场景下的问题解决却十分有用。通过使用这些小程序,开发人员可以快速完成一些个别需求的开发,提高了开发效率。 总之,500套java实用代码涵盖了Java博客项目、工具类和小程序。这些代码能够帮助开发人员解决常见的问题,提高开发效率并提供了一些可靠的解决方案。无论是个人开发者还是团队开发者,都可以从中受益并提高自己的开发水平。 ### 回答2: 500套Java实用代码包括Java博客项目、工具类和小程序等。 Java博客项目: Java博客项目是一个基于Java开发的个人博客系统,它可以用来展示个人的技术博文、项目经验等。这个项目通常包含用户登录注册、文章管理、评论功能等,可以通过Spring Boot、MyBatis等框架来实现。通过这个项目,可以学习到如何构建一个完整的Java Web应用程序。 工具类Java工具类是一个集成了许多实用的Java函数和方法的类库,可以通过调用这些函数和方法来实现一些常用的操作。比如,可以包含字符串处理、日期处理、文件操作、网络通信、加密解密、数据格式转换等功能。通过使用这些工具类,我们可以提高开发速度并提升代码质量。 小程序: 小程序是在移动设备上运行的一种轻量级应用程序,它通常提供一些特定的功能和服务。对于Java来说,可以使用Android Studio开发Android小程序,或者使用JavaFX开发桌面版小程序。这些小程序可以包括天气预报、股票行情、日记本等功能。通过开发小程序,我们可以了解Java在移动设备上的应用开发。 总的来说,500套Java实用代码的内容非常丰富,涵盖了Java博客项目、工具类和小程序等各个方面。通过学习和实践这些代码,我们可以提高自己的编程水平,掌握更多的Java技术。同时,这些实用代码也可以作为我们日常开发中的参考和借鉴。 ### 回答3: Java是一种广泛应用于软件开发领域的编程语言,具有丰富的类库和工具。500套Java实用代码就意味着有500个具有实用功能的代码示例。这些示例可以涵盖各个方面,下面以Java博客项目、工具类和小程序为例进行说明。 首先是Java博客项目。一个Java博客项目可以包含用户登录、文章发布、评论管理等功能,为用户提供了良好的博客发表和交流的平台。在这套实用代码中,可以包含博客的数据库设计、用户认证、文章展示和评论管理等方面的实现代码,帮助开发人员更好地理解并搭建Java博客项目。 其次是工具类工具类Java编程中常用的一种类,它提供了一些常用的函数或方法,帮助开发人员简化代码的编写。对于这套实用代码,可以提供一系列常用工具类示例,例如字符串处理、文件操作、日期时间处理等。这些示例可以为开发人员提供参考和使用,提高代码的效率和可读性。 最后是小程序。小程序是近年来非常流行的一种移动互联网应用形式,可以在手机上直接运行,无需下载安装。在这套实用代码中,可以包括一些Java实现的小程序示例,例如音乐播放器、天气查询、日程管理等。这些示例可以帮助开发人员了解小程序的基本架构和开发流程,快速上手开发自己的小程序项目。 综上所述,500套Java实用代码可以涵盖Java博客项目、工具类和小程序等多个方面。这些代码示例可以帮助开发人员更深入地了解Java编程,提高开发效率和质量。无论是在学习Java还是实际项目开发中,这些实用代码都是非常有价值的参考和工具。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

IT枫斗者

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值