还是因为填充自建数据表需要,需要一定范围内的随机日期,目标是优雅简洁高效.
思路有二:
- 生成一个符合要求的
13
位随机数作为毫秒,将毫秒转化为java.sql
包中的Date
类 - 生成随机的年月,再根据年月确定日的范围,生成随机日.
先上代码,随后进行效率对比.
指定范围为2016年-2018年(即2016年1月1日
起-2018年12月31日
止)
生成十三位随机数的方法:
public static Date randomHireday() {
int startYear=2016; //指定随机日期开始年份
int endYear=2018; //指定随机日期开始年份(含)
long start = Timestamp.valueOf(startYear+1+"-1-1 0:0:0").getTime();
long end = Timestamp.valueOf(endYear+"-1-1 0:0:0").getTime();
long ms=(long) ((end-start)*Math.random()+start); //获得了符合条件的13位毫秒数
Date hireday=new Date(ms);
return hireday;
}
循环十次:
分别生成随机的年月日:
public static Date randomHireday2() {
int startYear=2016;
int endYear=2018;
int year = (int)(Math.random()*(endYear-startYear+1))+startYear; //随机年
int month= (int)(Math.random()*12)+1; //随机月
Calendar c = Calendar.getInstance(); //创建Calendar对象
c.set(year, month, 0); //设定日期
int dayOfMonth = c.get(Calendar.DAY_OF_MONTH); //获取对应年月有几天
int day=(int)(Math.random()*dayOfMonth+1) ; //产生随机日
Date hireday=Date.valueOf(year+"-"+month+"-"+day); //通过valueOf方法生成Date对象
return hireday;
}
循环十次:
现在开始测试效率,分别做10
次短测试和100000
次长测试:
public static void main(String[] args) {
//随机十三位数
long start;
long end;
start = System.currentTimeMillis();
for(int i=0;i<10;i++) {
randomHireday();
}
end = System.currentTimeMillis();
System.out.println("随机十三位数10次循环所用时间:"+(end-start));
start = System.currentTimeMillis();
for(int i=0;i<100000;i++) {
randomHireday();
}
end = System.currentTimeMillis();
System.out.println("随机十三位数100000次循环所用时间:"+(end-start));
//分别随机生成年月日
start = System.currentTimeMillis();
for(int i=0;i<10;i++) {
randomHireday2();
}
end = System.currentTimeMillis();
System.out.println("分别随机生成年月日10次循环所用时间:"+(end-start));
start = System.currentTimeMillis();
for(int i=0;i<100000;i++) {
randomHireday2();
}
end = System.currentTimeMillis();
System.out.println("分别随机生成年月日100000次循环所用时间:"+(end-start));
}
显然较为简洁优雅的十三位随机数法的效率更高.
由此可见我们得到了优雅简洁高效的随机日期生成方法.