最近参与答题竞赛项目开发,涉及到较小的一个点,数字参赛码的创建,
初版没过多考虑,简单构建程序返回6位数字验证码即可,但后期在缓存中发现用户验证码出现4位,5位,6位的情况,回头翻看自己程序发现Math的随机数生成可能会出现下面情况,
Integer random = (int) ((Math.random() * 9) * 100000);
//随机数: ruandom: 0.5813246276193915
//随机数: ruandom乘9: 5.231921648574524
//随机数: ruandom乘9乘100000: 523192.1648574524
//随机数: ruandom乘9乘100000并转int: 523192
//随机数: ruandom: 0.024047056894756613
//随机数: ruandom乘9: 0.21642351205280952
//随机数: ruandom乘9乘100000: 21642.351205280953
//随机数: ruandom乘9乘100000并转int: 2164
后续对程序简单微调为下面形式
Integer random= (int)((Math.random()*9+1) *100000);
不论随机生成的小数点后有几个0最终都会有100000这个数兜底确保验证码的位数固定。问题很简单程序也很简单,在此做个问题记录,方便后期温习。