定时器Timer、多线程下的单例模式

在java中,Timer主要负责计划任务的功能,即在指定的时间开始执行某个任务。TimerTask是一个抽象类,负责封装定时任务。

1、定时器Timer的使用

schedule(TimerTask task, Date date):在指定的日期执行一次task。

schedule(TimerTask task, Date date, long period):在指定的日期date之后,按照period周期,无限循环执行task

TimerTask类中的cancel方法是将从任务队列中将任务自身移除。

Timer类的cancel方法是将任务队列中的全部任务进行清空,需要抢到任务队列的锁之后才能进行清理。

schedule(TimerTask task, long delay):以当前时间为基准,延迟delay的毫秒数后,执行一次task。

schedule(TimerTask task, long delay, long period):以当前时间为基准,延迟delay的毫秒数后,再以period为周期,周期性执行task。

scheduleAtFixedRate(TimerTask task, Date firstTime, long period):以firstTime为基准,以period为周期,周期性执行task。

定时器任务不一定准时执行,有可能时到达指定时间后,cpu被其他线程的同步区域占用。这时,待获得cpu执行时间片段后,才会执行定时任务。如果定时时间比当前时间早,定时任务会立即执行。

2、单例模式

volatile+double-check+延迟加载方式

java 复制代码
public class Singlton {
private volatile static Singlton instance;
private Singlton() { }
/**
* DCL双检查锁机制的延迟加载单例
* @return
*/
public static Singlton getInstance() {
if(instance!=null) {
}else{
synchronized(Singlton.class) {
if(instance==null) {
instance=new Singlton();
}
}
}
return instance;
}
}

内置类方式

java 复制代码
public class Singlton {
private static class SingltonHandler {
private static Singlton instance=new Singlton();
}
private Singlton() {}
/**
* 静态内置类实现单例模式
* @return
*/
public static Singlton getInstance() {
return SingltonHandler.instance;
}
}

内置类+序列化和反序列化方式

java 复制代码
import java.io.ObjectStreamException;
import java.io.Serializable;

public class Singlton implements Serializable{
private static final long serialVersionUID = -7197411174599222772L;

private static class SingltonHandler {
private static Singlton instance=new Singlton();
}
private Singlton() {}
/**
* 静态内置类实现单例模式
* @return
*/
public static Singlton getInstance() {
return SingltonHandler.instance;
}
/*
* 保证了单例模式下,单态对象序列化和反序列化之后仍然维持一致
*/
protected Object readResolve() throws ObjectStreamException{
return SingltonHandler.instance;
}
}

静态块方式

java 复制代码
public class Singlton {
private static Singlton instance;
private Singlton() {}
static {
instance=new Singlton();
}
/**
* 静态代码块实现单例模式
* @return
*/
public static Singlton getInstance() {
return instance;
}


}

枚举方式

java 复制代码
//枚举类型本身是final的,不允许被继承
public enum Singlton {
INSTANCE;
Singlton() {}
/**
* 枚举类型的实现
* @return
*/
public static Singlton getInstance() {
return INSTANCE;
}


}

延迟加载+枚举内置方式

java 复制代码
public class Singlton {
private Singlton() {}
private enum EnumHolder{
INSTANCE;
private Singlton singlton;
EnumHolder(){
this.singlton=new Singlton();
}
private Singlton getSinglton() {
return this.singlton;
}
}
/**
* 枚举类型的实现
* @return
*/
public static Singlton getInstance() {
return EnumHolder.INSTANCE.getSinglton();
}

}
相关推荐
一方热衷.1 小时前
YOLO26-Seg ONNXruntime C++/python推理
开发语言·c++·python
靓仔建2 小时前
Vue3导入组件出错does not provide an export named ‘user_setting‘ (at index.vue:180:10)
开发语言·前端·typescript
HalvmånEver2 小时前
7.高并发内存池大页内存申请释放以及使用定长内存池脱离new
java·spring boot·spring
凤山老林2 小时前
SpringBoot 使用 H2 文本数据库构建轻量级应用
java·数据库·spring boot·后端
赶路人儿3 小时前
UTC时间和时间戳介绍
java·开发语言
dreamread3 小时前
【SpringBoot整合系列】SpringBoot3.x整合Swagger
java·spring boot·后端
6+h3 小时前
【java】基本数据类型与包装类:拆箱装箱机制
java·开发语言·python
一直都在5723 小时前
Spring面经
java·后端·spring
xiaoye37083 小时前
如何在Spring中使用注解配置Bean的生命周期回调方法?
java·spring
闻哥4 小时前
深入Redis的RDB和AOF两种持久化方式以及AOF重写机制的分析
java·数据库·spring boot·redis·spring·缓存·面试