JAVA开发常用类库UUID、Optional、ThreadLocal、TimerTask、Base64使用方法与实例详解

 更新时间:2020年02月19日 14:33:17   作者:彭世瑜  
这篇文章主要介绍了JAVA开发常用类库UUID、Optional、ThreadLocal、TimerTask、Base64使用方法与实例详解,需要的朋友可以参考下

1、UUID类库

UUID 根据时间戳实现自动无重复字符串定义

// 获取UUID
public static UUID randomUUID()

// 根据字符串获取UUID
public static UUID fromString(String name)

应用:对文件进行自动命名处理

import java.util.UUID;

class Demo {

  public static void main(String[] args) {
    System.out.println(UUID.randomUUID());
    // 85a8ccb1-88f8-4b3c-833d-d45b58e0204e

    System.out.println(UUID.fromString("85a8ccb1-88f8-4b3c-833d-d45b58e0204e"));
    // 85a8ccb1-88f8-4b3c-833d-d45b58e0204e
  }
}

2、Optional类库

Optional 主要功能是进行null空指针处理

JDK >= 1.8

示例:单独处理null参数

class Message{
  private String message;

  public Message(String message) {
    this.message = message;
  }

  public String getMessage(){
    return this.message;
  }
}

class Demo {
  public static void showMessage(Message message) {
    if(message != null){
      System.out.println(message.getMessage());
    }
  }

  public static void main(String[] args) {
    Message message = new Message("这是消息");
    showMessage(message);

    showMessage(null);
  }
}

几个方法

public final class Optional<T> {

   public static<T> Optional<T> empty() {
    @SuppressWarnings("unchecked")
    Optional<T> t = (Optional<T>) EMPTY;
    return t;
  }

  public static <T> Optional<T> of(T value) {
    return new Optional<>(value);
  }

   public static <T> Optional<T> ofNullable(T value) {
    return value == null ? empty() : of(value);
  }

  public T get() {
    if (value == null) {
      throw new NoSuchElementException("No value present");
    }
    return value;
  }

  public T orElse(T other) {
    return value != null ? value : other;
  }
}

使用示例

import java.util.Optional;

/**
 * 存入
*/
Optional<String> optOf = Optional.of("message");
// Optional<String> optOfNull = Optional.of(null);
// java.lang.NullPointerException

Optional<String> optOfNullable = Optional.ofNullable("message");
Optional<String> optOfNullableNull = Optional.ofNullable(null);


/**
 * 取出
*/
System.out.println(optOf.get());
// message

System.out.println(optOfNullable.get());
// message

// System.out.println(optOfNullableNull.get());
// java.util.NoSuchElementException: No value present

System.out.println(optOf.orElse("default"));
// message

System.out.println(optOfNullable.orElse("default"));
// message

System.out.println(optOfNullableNull.orElse("default"));
// default

自定义函数实现

class Demo {
  public static String getDefault(String object, String defaultValue){
    return object != null ? object : defaultValue;
  }

  public static void main(String[] args) {
    System.out.println(getDefault("message", "default"));
    // message

    System.out.println(getDefault(null, "default"));
    // default
  }
}

3、ThreadLocal类库

ThreadLocal解决线程同步问题

public T get() 
public void set(T value)
public void remove()

定义发送消息类

class Message{
  private String message ;

  public Message(String message) {
    this.message = message;
  }

  public String getMessage(){
    return this.message;
  }
}

class Channel{
  private static Message message;

  public static void setMessage(Message msg){
    message = msg;
  }

  public static void send(){
    System.out.println(message.getMessage());
  }

}

单线程下运行

class Demo {
  public static void main(String[] args) {
    Message message = new Message("你好");
    Chanel.setMessage(message);
    Chanel.send();
    // 你好
  }
}

多线程下运行,出现数据覆盖现象

class Demo {
  public static void main(String[] args) {
    new Thread(()->{
      Channel.setMessage(new Message("你好-1"));
      Channel.send();
    }, "线程-1").start();

    new Thread(()->{
      Channel.setMessage(new Message("你好-2"));
      Channel.send();
    }, "线程-2").start();

    new Thread(()->{
      Channel.setMessage(new Message("你好-3"));
      Channel.send();
    }, "线程-3").start();
    /**
     * 线程-2 你好-3
     * 线程-1 你好-1
     * 线程-3 你好-3
     */
  }
}

改造 Channel

class Channel{

  // private static Message message;
  private static final ThreadLocal<Message> THREAD_LOCAL = new ThreadLocal<Message>();

  public static void setMessage(Message msg){
    THREAD_LOCAL.set(msg);
  }

  public static void send(){
    System.out.println(Thread.currentThread().getName()
        + " "
        + THREAD_LOCAL.get().getMessage());
  }  
}

// 执行后数据对应
/**

线程-2 你好-2
线程-1 你好-1
线程-3 你好-3
*/

ThreadLocal, 只允许保存一个数据

4、TimerTask类库定时调度

定时器进行定时任务处理,实现了一种间隔触发操作

java.util.TimerTask 定时任务处理

java.util.Timer 任务启动

// 定时启动
public void schedule(TimerTask task, long delay)

// 间隔任务
public void scheduleAtFixedRate(TimerTask task, long delay, long period)

定义任务

import java.util.TimerTask;

class MyTask extends TimerTask{

  @Override
  public void run() {
    System.out.println("任务启动 " + System.currentTimeMillis());
  }
}

示例:定时启动,会卡主

import java.util.Timer;

class Demo {
  public static void main(String[] args) {
    Timer timer = new Timer();
    timer.schedule(new MyTask(), 100);
    // 任务启动 1574260837613
  }
}

示例:间隔任务

class Demo {
  public static void main(String[] args) {
    Timer timer = new Timer();
    timer.scheduleAtFixedRate(new MyTask(), 100, 1000);
  }
}

5、Base64类库加密与解密

加密解密示例

String message = "Hello Java";

String encodeMessage = new String(Base64.getEncoder().encode(message.getBytes()));

System.out.println(encodeMessage);

// SGVsbG8gSmF2YQ==

String decodeMessage = new String(Base64.getDecoder().decode(encodeMessage));

System.out.println(decodeMessage);

// Hello Java

最好的方法是使用2-3中加密程序,进行多次加密

加密解密示例

import java.util.Base64;

class Crypto{
  // 加密重复次数,越高越安全
  private static final int REPEAT = 3;

  /**
   * 加密处理
   * @param message
   * @return
   */
  public static String encode(String message){
    byte[] data = message.getBytes();

    // 重复加密
    for (int i = 0; i < REPEAT; i++) {
      data = Base64.getEncoder().encode(data);
    }

    return new String(data);
  }

  public static String decode(String message){
    byte[] data = message.getBytes();

    for (int i = 0; i < REPEAT; i++) {
      data = Base64.getDecoder().decode(data);
    }

    return new String(data);
  }
}

class Demo {
  public static void main(String[] args) {
    String message = "Hello Java";

    String encodeMessage = Crypto.encode(message);
    System.out.println(encodeMessage);
    // VTBkV2MySkhPR2RUYlVZeVdWRTlQUT09

    String decodeMessage = Crypto.decode(encodeMessage);
    System.out.println(decodeMessage);
    // Hello Java
  }
}

本文主要介绍了JAVA开发过程中常用类库UUID、Optional、ThreadLocal、TimerTask、Base64的基础使用方法,更多关于UUID、Optional、ThreadLocal、TimerTask、Base64类库的详细使用方法请查看下面的相关链接

相关文章

  • springboot参数传中文乱码的解决方案

    springboot参数传中文乱码的解决方案

    这篇文章主要介绍了springboot参数传中文乱码的解决方案,帮助大家更好的理解和学习使用springboot,感兴趣的朋友可以了解下
    2021-03-03
  • Spring超详细讲解AOP面向切面

    Spring超详细讲解AOP面向切面

    面向对象编程是一种编程方式,此编程方式的落地需要使用“类”和 “对象”来实现,所以,面向对象编程其实就是对 “类”和“对象” 的使用,面向切面编程,简单的说,就是动态地将代码切入到类的指定方法、指定位置上的编程思想就是面向切面的编程
    2022-10-10
  • Java构建对象常用3种方法解析

    Java构建对象常用3种方法解析

    这篇文章主要介绍了Java构建对象常用3种方法解析,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
    2020-09-09
  • MyBatis-Plus中MetaObjectHandler没生效完美解决

    MyBatis-Plus中MetaObjectHandler没生效完美解决

    在进行测试时发现配置的MyMetaObjectHandler并没有生效,本文主要介绍了MyBatis-Plus中MetaObjectHandler没生效完美解决,具有一定的参考价值,感兴趣的可以了解一下
    2023-11-11
  • SpringBoot集成Mybatis-plus并实现自动生成相关文件的示例代码

    SpringBoot集成Mybatis-plus并实现自动生成相关文件的示例代码

    Mybatis-Plus是一个优秀的Mybatis增强工具,目前更新到3.1.1,本文通过示例代码给大家介绍SpringBoot集成Mybatis-plus并实现自动生成相关文件的问题,感兴趣的朋友跟随小编一起看看吧
    2021-12-12
  • java中字符进行全角半角转换示例代码

    java中字符进行全角半角转换示例代码

    全角:指一个字符占用两个标准字符位置,而半角:指一字符占用一个标准的字符位置,在日常开发中经常会遇到全角半角转换的要求,下面这篇文章主要给大家介绍了关于java中字符进行全角半角转换的相关资料,文中通过示例代码介绍的非常详细,需要的朋友可以参考下。
    2017-08-08
  • Java AtomicInteger类的重要方法和特性

    Java AtomicInteger类的重要方法和特性

    AtomicInteger是Java中的一个类,用于实现原子操作的整数,AtomicInteger类主要用于处理整数类型的原子操作,本文给大家介绍Java AtomicInteger类的重要方法和特性,感兴趣的朋友一起看看吧
    2023-10-10
  • springboot2.0以上调度器配置线程池的实现

    springboot2.0以上调度器配置线程池的实现

    这篇文章主要介绍了springboot2.0以上调度器配置线程池的实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2019-12-12
  • java基本教程之synchronized关键字 java多线程教程

    java基本教程之synchronized关键字 java多线程教程

    这篇文章主要介绍了java的synchronized原理、synchronized基本规则、synchronized方法 和 synchronized代码块、实例锁和全局锁
    2014-01-01
  • Java深入分析动态代理

    Java深入分析动态代理

    动态代理指的是,代理类和目标类的关系在程序运行的时候确定的,客户通过代理类来调用目标对象的方法,是在程序运行时根据需要动态的创建目标类的代理对象。本文将通过案例详细讲解一下Java动态代理的原理及实现,需要的可以参考一下
    2022-07-07

最新评论