java time_java time 定时器的三种基本用法

import java.util.Random;

import java.util.Timer;

import java.util.TimerTask;

/**

* @description jdk time时间定时器的三种用法。

* @author LUKE

* @time 2018年5月28日 下午2:57:02

*/

public class TimeTest {

public static void main(String[] args) {

long startTime = System.currentTimeMillis();

System.out.println("startTime="+startTime);

// long delay = 2000;

// long period = 4000;

// 在延迟delay毫秒后执行一次任务。(只执行一次)

// timeSchedule(startTime, 2000);

// 在延迟delay毫秒后执行一次任务,然后以period毫秒间隔的频率执行。

// timeScheduleLoop(startTime, delay, period);

// 在延迟delay毫秒后执行一次任务,然后以period毫秒间隔的频率执行。

// timeScheduleAtFixedRate(startTime, delay, period);

long endTime = System.currentTimeMillis();

System.out.println("endTime="+endTime+", 共耗时:"+(endTime - startTime)+"毫秒。");

}

/**

* @description 在延迟delay毫秒后执行一次任务,然后以period毫秒间隔的频率执行。

* @author LUKE

* @time 2018年5月28日 下午2:56:28

* @param startTime

* @param delay

* @param period

*/

public static void timeScheduleAtFixedRate(long startTime, long delay, long period) {

Timer timer = new Timer();

timer.scheduleAtFixedRate(new TimerTask() {

@Override

public void run() {

long taskTime = System.currentTimeMillis();

System.out.println("taskTime="+taskTime+", 间隔"+(taskTime - startTime)+"毫秒。");

int len = 100000000;

int [] arrs = new int [len];

for(int i = 0; i < len; i++){

arrs[i] = new Random().nextInt();

// System.out.print(arrs[i]+" # ");

}

long taskEndTime = System.currentTimeMillis();

System.out.println("taskEndTime="+taskEndTime+", 任务循环耗时"+(taskEndTime - taskTime)+"毫秒。");

System.out.println("********************************************");

}

}, delay, period);

}

/**

* @description 在延迟delay毫秒后执行一次任务,然后以period毫秒间隔的频率执行。

* @author LUKE

* @time 2018年5月28日 下午2:29:43

* @param startTime

* @param delay

* @param period

*/

public static void timeScheduleLoop(long startTime, long delay, long period) {

Timer timer = new Timer();

timer.schedule(new TimerTask() {

@Override

public void run() {

long taskTime = System.currentTimeMillis();

System.out.println("taskTime="+taskTime+", 间隔"+(taskTime - startTime)+"毫秒。");

int len = 100000000;

int [] arrs = new int [len];

for(int i = 0; i < len; i++){

arrs[i] = new Random().nextInt();

// System.out.print(arrs[i]+" # ");

}

long taskEndTime = System.currentTimeMillis();

System.out.println("taskEndTime="+taskEndTime+", 任务循环耗时"+(taskEndTime - taskTime)+"毫秒。");

System.out.println("********************************************");

}

}, delay, period);

}

/**

* @description 在延迟delay毫秒后执行一次任务。(只执行一次)

* @author LUKE

* @time 2018年5月28日 上午10:12:19

* @param startTime

*/

public static void timeSchedule(long startTime, long delay) {

Timer timer = new Timer();

timer.schedule(new TimerTask() {

@Override

public void run() {

long taskTime = System.currentTimeMillis();

System.out.println("taskTime="+taskTime+", 等待"+(taskTime - startTime)+"毫秒。 do task...");

}

}, delay);

}

}

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值