1.首先我们定义一个抽象接口
像这样,这个就是我们要使用的定时执行中重要的回调函数方法
interface Callback {
void Once_per_second();
}
2. 我们在写一个类用于写我们的接口我这边用的是内部类(有较大误差定时函数)
这样就完成我们的回调方法
static class erratic_function {
}
再然后就是重点部分了,也就是我们的Java定时执行方法的核心代码,但是这个方法执行起来会有极大的误差大致有一下几点(这个对于我们日常使用和开发来说并没有用,所以这个直供参考不建议使用)
1.执行时间从当前开始时间不好处理。
2.程序执行的时间无法减去,导致长时间执行会有无限可能得误差。
static class erratic_function {
/**
* @param callback 秒钟执行
*/
void second_TSTSP(Callback callback) {
// 执行某些操作
Timer timer = new Timer();
TimerTask task = new TimerTask() {
@Override
public void run() {
long startTime = System.currentTimeMillis();
callback.Once_per_second();
long endTime = System.currentTimeMillis();
long executionTime = endTime - startTime;
System.out.println("方法执行时间:" + executionTime + "毫秒");
}
};
timer.schedule(task, 0, 1000);
}
}
这个方法能使用了我们的定时函数方法然后在以回调的方式执行,还有一个对程序执行速度进行计时的
long startTime = System.currentTimeMillis();
//放入需要检测的执行方法或计算
long endTime = System.currentTimeMillis();
long executionTime = endTime - startTime;
System.out.println("方法执行时间:" + executionTime + "毫秒");
3.定时函数pulls版这个版本是我根据定时函数的多调用进行处理了的,一个定时方法有较大的稳定性暂时没发现啥问题。
直接上代码吧,这种处理方法我尝试了一下测试了半个小时没有发现有超过秒级的有达到100毫秒的误差
static class rule_function {
/**
* 自定义执行
*
* @param callback 回调函数
* @param second 执行时长 秒
*/
void custom_second(Callback callback, int second) {
Timer timer = new Timer();
long sum = second * 1000L;
// 执行某些操作
TimerTask tasks = new TimerTask() {
@Override
public void run() {
// 获取当前时间
long currentTime = System.currentTimeMillis();//在每次重新执行时需要重新获取当前时间 防止程序执行时间影响整个程序调用时间规则出现异常
int sec = second * 1000;//转换为秒级
long delay = sec - (currentTime % sec);//进行计算 当前时间还差多少毫秒到某一个整秒
System.out.println(delay);
TimerTask task = new TimerTask() {
@Override
public void run() {
long startTime = System.currentTimeMillis();
callback.Once_per_second();
long endTime = System.currentTimeMillis();
long executionTime = endTime - startTime;
System.out.println("方法执行时间:" + executionTime + "毫秒");
}
};
timer.schedule(task, delay);
}
};
// 计算距离下一分钟整点的时间差
// 设置定时任务,在距离下一分钟整点时执行MyTask中的run方法
timer.schedule(tasks, 0, sum);
}
void custom_minute(Callback callback, int second) {
Timer timer = new Timer();
long sum = second * 60000L;
// 执行某些操作
TimerTask tasks = new TimerTask() {
@Override
public void run() {
// 获取当前时间
long currentTime = System.currentTimeMillis();//在每次重新执行时需要重新获取当前时间 防止程序执行时间影响整个程序调用时间规则出现异常
int sec = second * 60000;//转换为秒级
long delay = sec - (currentTime % sec);//进行计算 当前时间还差多少毫秒到某一个整秒
System.out.println(delay);
TimerTask task = new TimerTask() {
@Override
public void run() {
}
};
timer.schedule(task, delay);
}
};
// 计算距离下一分钟整点的时间差
// 设置定时任务,在距离下一分钟整点时执行MyTask中的run方法
timer.schedule(tasks, 0, sum);
}
}
4.在来一个完整代码吧
package com.mrmt.Time_processing;
import java.text.SimpleDateFormat;
import java.util.*;
public class Time_processing {
interface Callback {
void Once_per_second();
}
static class rule_function {
/**
* 自定义执行
*
* @param callback 回调函数
* @param second 执行时长 秒
*/
void custom_second(Callback callback, int second) {
Timer timer = new Timer();
long sum = second * 1000L;
// 执行某些操作
TimerTask tasks = new TimerTask() {
@Override
public void run() {
// 获取当前时间
long currentTime = System.currentTimeMillis();//在每次重新执行时需要重新获取当前时间 防止程序执行时间影响整个程序调用时间规则出现异常
int sec = second * 1000;//转换为秒级
long delay = sec - (currentTime % sec);//进行计算 当前时间还差多少毫秒到某一个整秒
System.out.println(delay);
TimerTask task = new TimerTask() {
@Override
public void run() {
long startTime = System.currentTimeMillis();
callback.Once_per_second();
long endTime = System.currentTimeMillis();
long executionTime = endTime - startTime;
System.out.println("方法执行时间:" + executionTime + "毫秒");
}
};
timer.schedule(task, delay);
}
};
// 计算距离下一分钟整点的时间差
// 设置定时任务,在距离下一分钟整点时执行MyTask中的run方法
timer.schedule(tasks, 0, sum);
}
void custom_minute(Callback callback, int second) {
Timer timer = new Timer();
long sum = second * 60000L;
// 执行某些操作
TimerTask tasks = new TimerTask() {
@Override
public void run() {
// 获取当前时间
long currentTime = System.currentTimeMillis();//在每次重新执行时需要重新获取当前时间 防止程序执行时间影响整个程序调用时间规则出现异常
int sec = second * 60000;//转换为秒级
long delay = sec - (currentTime % sec);//进行计算 当前时间还差多少毫秒到某一个整秒
System.out.println(delay);
TimerTask task = new TimerTask() {
@Override
public void run() {
}
};
timer.schedule(task, delay);
}
};
// 计算距离下一分钟整点的时间差
// 设置定时任务,在距离下一分钟整点时执行MyTask中的run方法
timer.schedule(tasks, 0, sum);
}
}
// 包含回调方法的类
static class erratic_function {
/**
* @param callback 秒钟执行
*/
void second_TSTSP(Callback callback) {
// 执行某些操作
Timer timer = new Timer();
TimerTask task = new TimerTask() {
@Override
public void run() {
long startTime = System.currentTimeMillis();
callback.Once_per_second();
long endTime = System.currentTimeMillis();
long executionTime = endTime - startTime;
System.out.println("方法执行时间:" + executionTime + "毫秒");
}
};
timer.schedule(task, 0, 1000);
}
/**
* @param callback 分钟执行
*/
void minute_TSTSP(Callback callback) {
// 执行某些操作
Timer timer = new Timer();
TimerTask task = new TimerTask() {
@Override
public void run() {
long startTime = System.currentTimeMillis();
callback.Once_per_second();
long endTime = System.currentTimeMillis();
long executionTime = endTime - startTime;
System.out.println("方法执行时间:" + executionTime + "毫秒");
}
};
timer.schedule(task, 0, 60000);
}
/**
* @param callback 小时
*/
void hour_TSTSP(Callback callback) {
// 执行某些操作
Timer timer = new Timer();
TimerTask task = new TimerTask() {
@Override
public void run() {
long startTime = System.currentTimeMillis();
callback.Once_per_second();
long endTime = System.currentTimeMillis();
long executionTime = endTime - startTime;
System.out.println("方法执行时间:" + executionTime + "毫秒");
}
};
timer.schedule(task, 0, 3600000);
}
/**
* @param callback 天
*/
void day_TSTSP(Callback callback) {
// 执行某些操作
Timer timer = new Timer();
TimerTask task = new TimerTask() {
@Override
public void run() {
long startTime = System.currentTimeMillis();
callback.Once_per_second();
long endTime = System.currentTimeMillis();
long executionTime = endTime - startTime;
System.out.println("方法执行时间:" + executionTime + "毫秒");
}
};
timer.schedule(task, 0, 3600000 * 24);
}
/**
* @param callback 回调内容
* @param minute 回调时长分钟级
*/
void custom_minute(Callback callback, int minute) {
// 执行某些操作
Timer timer = new Timer();
TimerTask task = new TimerTask() {
@Override
public void run() {
long startTime = System.currentTimeMillis();
callback.Once_per_second();
long endTime = System.currentTimeMillis();
long executionTime = endTime - startTime;
System.out.println("方法执行时间:" + executionTime + "毫秒");
}
};
timer.schedule(task, 0, minute * 60000);
}
/**
* @param callback 回调内容
* @param millisecond 回调时长 毫秒
*/
void custom_millisecond(Callback callback, int millisecond) {
// 执行某些操作
Timer timer = new Timer();
TimerTask task = new TimerTask() {
@Override
public void run() {
long startTime = System.currentTimeMillis();
callback.Once_per_second();
long endTime = System.currentTimeMillis();
long executionTime = endTime - startTime;
System.out.println("方法执行时间:" + executionTime + "毫秒");
}
};
timer.schedule(task, 0, millisecond);
}
}
public static void Content_display(Object... T) {
System.out.println("按照传入顺序打印");
for (Object o : T) {
int lastIndex = o.getClass().getName().lastIndexOf(".");
String result = o.getClass().getName().substring(lastIndex + 1);
System.out.println(" 类型 : " + result + " 内容 : " + o);
}
}
public static void main(String[] args) {
erratic_function example = new erratic_function();
rule_function rule_function = new rule_function();
rule_function.custom_second(new Callback() {
@Override
public void Once_per_second() {
Date currentTime = new Date();
// 定义时间格式
SimpleDateFormat sdf = new SimpleDateFormat("HH:mm:ss.SSS");
// 格式化时间并打印
String formattedTime = sdf.format(currentTime);
System.out.println("十秒: " + formattedTime);
System.out.println("启动");
}
}, 10);
rule_function.custom_minute(new Callback() {
@Override
public void Once_per_second() {
Date currentTime = new Date();
// 定义时间格式
SimpleDateFormat sdf = new SimpleDateFormat("HH:mm:ss.SSS");
// 格式化时间并打印
String formattedTime = sdf.format(currentTime);
System.out.println("一分: " + formattedTime);
System.out.println("启动");
}
}, 1);
}
}
下面这个是我写的一个打印方法还没完善好希望有想法的铁汁评论一下说一下咋改比较合适
package com.mrmt.Time_processing;
public class Main {
public static void main(String[] args) {
gets("1", 2, "3");
}
public static void gets(String name, int age, String type) {
Content_display(name, age, type);
}
public static void Content_display(Object... T) {
System.out.println("按照传入顺序打印");
for (Object o : T) {
int lastIndex = o.getClass().getName().lastIndexOf(".");
String result = o.getClass().getName().substring(lastIndex + 1);
System.out.println(" 类型 : " + result + " 内容 : " + o);
}
}
}