Java线程补充知识

一、定时器

1 概述

  • 定时器是一种控制任务延时调用,或者周期调用的技术
  • 作用:闹钟、定时邮件发送
  • 实现方式:1 Timer    2  ScheduledExecutorService

2 Timer定时器

/**
    目标:Timer定时器的使用和了解
 */

public class TimerDemo1 {
    public static void main(String[] args) {
        //1、创建Timer定时器
        Timer timer=new Timer();    //定时器本身就是一个单线程
        //2、调用方法,处理定时任务
        timer.schedule(new TimerTask() {
            @Override
            public void run() {
                System.out.println(Thread.currentThread().getName()+"执行一次~~~");
            }
        },3000,2000);
    }
}

 

3 Timer定时器的特点和存在的问题

  • Timer是单线程,处理多个任务按照顺序执行,存在延时与设置定时器的时间有出入

  • 可能因为其中的某个任务的异常使Timer线程死掉,从而影响后续任务执行 

public class TimerDemo1 {
    public static void main(String[] args) {
        //1、创建Timer定时器
        Timer timer=new Timer();    //定时器本身就是一个单线程
        //2、调用方法,处理定时任务
        timer.schedule(new TimerTask() {
            @Override
            public void run() {
                System.out.println(Thread.currentThread().getName()+"执行一次AAA~~~"+new Date());
                try {
                    Thread.sleep(5000);
                } catch (Exception e) {
                    e.printStackTrace();
                }
            }
        },0,2000);

        timer.schedule(new TimerTask() {
            @Override
            public void run() {
                System.out.println(Thread.currentThread().getName()+"执行一次BBB~~~"+new Date());
            }
        },0,2000);
    }
}

 4 ScheduledExecutorService定时器

        ScheduledExecutorService jdk1.5中引入了并发包,目的是为了弥补Timer的缺陷, ScheduledExecutorService内部为线程池。

 

public class TimerDemo2 {
    public static void main(String[] args) {
        //1、创建ScheduledExecutorService线程池,做定时器
        ScheduledExecutorService pool= Executors.newScheduledThreadPool(3);

        //2、开启定时任务
        pool.scheduleAtFixedRate(new TimerTask() {
            @Override
            public void run() {
                System.out.println(Thread.currentThread().getName()+"执行输出:AAA  ==>"+new Date());
                try {
                    Thread.sleep(5000);
                } catch (Exception e) {
                    e.printStackTrace();
                }
            }
        },0,2, TimeUnit.SECONDS);

        pool.scheduleAtFixedRate(new TimerTask() {
            @Override
            public void run() {
                System.out.println(Thread.currentThread().getName()+"执行输出:BBB  ==>"+new Date());
            }
        },0,2, TimeUnit.SECONDS);
    }
}

 二、并发、并行

        正在运行的程序就是一个独立的进程,线程是属于进程的,多个线程其实是并发与并行同时进行的。

        并发:1 CPU同时处理吸纳成的数量有限   2 CPU会轮询为系统的每线程服务,由于CPU切换速度很快,给我们的感觉这些线程在同时执行,这就是并发

        并行:在同一个时刻上,同时有多个线程在被CPU处理并执行

 三、线程的声明周期

  • Java线程共有6种状态,都定义在Thread类的内部枚举类中

 

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值