当前位置: 代码迷 >> 综合 >> 日期计算问题及int类型越界
  详细解决方案

日期计算问题及int类型越界

热度:46   发布时间:2023-10-01 02:02:26.0

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 范围正负231次方:+/- 2147483648365 * 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类:

new DecimalFormat("00.000").format(pi) //结果:03.142
new DecimalFormat("##.###").format(pi) //结果:3.142


  相关解决方案