1、SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");
使用sdf.parse(new Date().toString())格式不对,会报错:Unparseable date: "Sun Apr 08 14:24:53 CST 2018"
2、获得当前时间秒数不用 new Date().getTime();而使用System.currentTimemillis();
3、日期yyyy-MM-dd 和yyyy-MM-dd HH:mm:ss 相减时格式要一致,否则不会报错,但是得到的天数或月数或年数会相差一天或一个月或一年
4、日期yyyy-MM-dd 和yyyy-MM-dd HH:mm:ss 格式化时,与从数据库得到的数据格式不一致时,得到的天数或月数或年数会相差一天或一个月或一年
如,
String startDateStr = leaveDetailVo.getStartDate();//2018-04-08 14:48:52
SimpleDateFormat dateFormat = new SimpleDateFormat("yyyy-MM-dd");
// 获得病假开始年、月份
try {
cal.setTime(dateFormat.parse(startDateStr));
} catch (ParseException e1) {
BaseExceptionService.exceptionLogInfo(this.getClass().getName(), ExceptionConst.SICK_LEAVE_START_MONTH_YEAR_ERROR, "calculateAnnualLeave()");
}
int startYear = cal.get(Calendar.YEAR);
此时,得到的年数startYear会出错,应将其改为
SimpleDateFormat dateFormat = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");
5、计算两个日期相隔多少年
可直接使用两个日期的秒数相减,再除以相应的年数单位。
如下,计算迄今为止毕业多少年:
(System.currentTimeMillis()-sdf.parse(graduationTimeStr).getTime())/ManhoursConstants.ONE_DAY_TOTAL_MILLISECONDS;
public static final long ONE_DAY_TOTAL_MILLISECONDS = 365 * 24 * 3600 * 1000L;
注:计算秒数时,很可能出现int越界问题,如此地,一开始使用了int 定义常量:
public static final int ONE_DAY_TOTAL_MILLISECONDS = 365 * 24 * 3600 * 1000;
发现计算出的年数不正确。其后,发现,
Int 范围正负2的31次方:+/- 2147483648;365 * 24 * 3600 * 1000已经超过这个范围,所以计算就会出错
用long就可以了
6、long类型无论怎么计算都不会保留小数点,需要先将要进行计算的数先转为指定类型再计算才可
long diffDays = 275;
double actualAnnualLeave = Math.round(5.0 * diffDays / 365);//将其中一个数转为double型才可进行计算
7、double 保留小数位数,Double
类型默认值
0.0d
A:java Math.round()保留2位小数
B:DecimalFormat类: