守护线程
-
java语言中线程分为两大类:
- 一类是:用户线程
- 一类是:守护线程(后台线程)
- 其中具有代表性的就是:垃圾回收线程(守护线程)。
-
守护线程的特点:
- 一般守护线程是一个死循环,所有的用户线程只要结束,
- 守护线程自动结束。
-
注意:主线程main方法是一个用户线程。
-
守护线程用在什么地方呢?
- 每天00:00的时候系统数据自动备份。
- 这个需要使用到定时器,并且我们可以将定时器设置为守护线程。
- 一直在那里看着,没到00:00的时候就备份一次。所有的用户线程
- 如果结束了,守护线程自动退出,没有必要进行数据备份了。
定时器
- 定时器的作用:
- 间隔特定的时间,执行特定的程序。
- 每周要进行银行账户的总账操作。
- 每天要进行数据的备份操作。
- 在实际的开发中,每隔多久执行一段特定的程序,这种需求是很常见的,
那么在java中其实可以采用多种方式实现:- 可以使用sleep方法,睡眠,设置睡眠时间,没到这个时间点醒来,执行
任务。这种方式是最原始的定时器。(比较low) - 在java的类库中已经写好了一个定时器:java.util.Timer,可以直接拿来用。
不过,这种方式在目前的开发中也很少用,因为现在有很多高级框架都是支持
定时任务的。 - 在实际的开发中,目前使用较多的是Spring框架中提供的SpringTask框架,
这个框架只要进行简单的配置,就可以完成定时器的任务。
- 可以使用sleep方法,睡眠,设置睡眠时间,没到这个时间点醒来,执行
示例代码01:
/*
守护线程
*/
public class ThreadTest14 {
public static void main(String[] args) {
BakThread t = new BakThread();
t.setName("守护线程");
//把用户线程设置成守护线程
// 启动线程之前,将线程设置为守护线程
t.setDaemon(true);
//启动线程
t.start();
//主线程(用户线程)
// 主线程:主线程是用户线程
for(int i=0;i<10;i++){
System.out.println(Thread.currentThread().getName() + "--->" + i);
try {
Thread.sleep(1000);
} catch (InterruptedException e) {
e.printStackTrace();
}
}
}
}
class BakThread extends Thread{
public void run(){
int i=0;
// 即使是死循环,但由于该线程是守护者,当用户线程结束,守护线程自动终止。
while(true){
System.out.println(Thread.currentThread().getName() + "--->" + (++i));
try {
Thread.sleep(1000);
} catch (InterruptedException e) {
e.printStackTrace();
}
}
}
}
运行结果:
示例代码02:
public class TimerTest {
public static void main(String[] args) {
// 创建定时器对象
Timer time = new Timer();
SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd HH-mm-ss");
Date timedate = null;
try {
timedate = sdf.parse("2022-9-8 14-07-30");
} catch (ParseException e) {
e.printStackTrace();
}
// 指定定时任务
//timer.schedule(定时任务, 第一次执行时间, 间隔多久执行一次);
time.schedule(new LogTimerTest(),timedate,1000 * 2);
}
}
// 编写一个定时任务类
// 假设这是一个记录日志的定时任务
class LogTimerTest extends TimerTask{
@Override
public void run() {
// 编写你需要执行的任务就行了。
SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd HH-mm-ss");
String strtime = sdf.format(new Date());
System.out.println(strtime + ": 成功完成了一次备份!");
}
}