项目中有个功能,要求记录单据从上一级审批到下一级审批的所需时间,不常用日期转换之类的东西,所以记录在此,以备后用。
代码如下
package com.tdhc.puPriceParityManagement.util;
import java.text.DateFormat;
import java.text.SimpleDateFormat;
import java.util.Date;
/**
* 计算从上一级审核时间到下一级审核时间的小时数
*/
public class RequiredTimeHours {
public static int getHours(Date date) {
try {
//将传入的日期类型转化为固定的格式,以便获取参数时间的毫秒数
DateFormat sdf = new SimpleDateFormat("yyyy-MM-dd hh:mm:ss");
String format = sdf.format(date);
//获取参数毫秒数
long time = sdf.parse(format).getTime();
//在中间加个循环,以加大时间差
for(int i=0;i<50;i++){
System.out.print(i+"-");
}
//获取系统当前时间的毫秒数
long l = System.currentTimeMillis();
//两者相减,获得时间差的毫秒数
long mills = l - time;
System.out.println(mills);//如果这里的值不为零 证明时间差计算成功
//将时间差的毫秒数转化成整个的小时数
int requiredHours = (int) (mills / 1000 / 3600);
//将所需时间返回
return requiredHours;
} catch (Exception e) {
//返回一个0,代表执行出现异常
return 0;
}
}
public static void main(String[] args) {
System.out.println(getHours(new Date()));
}
}
Note:当时为了测试,就直接传入的new Date()函数,与System.currentTimeMillis()相差太小,所以在代码中我加入了一段50次的循环以加大时间差,然后以便查看测试效果,可以忽略。
本文介绍了一个实用的方法,用于计算从上一级审批到下一级审批所需的时间差,通过将日期转换为固定格式并获取毫秒数,进而计算出两时间点间的时间差,并将其转换为小时数。
2万+

被折叠的 条评论
为什么被折叠?



