• 在使用Math.random()生成6位随机数遇到的问题,并成功得到6位随机数


    最近在做卫生局的一个考务网时需要实现一个短信发送验证码的功能,因此就必须使用到随机生成6位验证码的功能,开始觉的简单的,随便写了个

    int i=(int)(Math.random()*1000000+100000); 
    String messageCode = String.valueOf(i);

    然后测试发送了下,是发送了6位随机数,以为是正确的,但在之后的反复测试中忽然发现这个验证码有时会出现7位的,然后去看代码感觉没问题啊,

    Math.random()是产生0.0到1.0之间的doule的随机数的,感觉不会错啊

    没办法测试下,写个main函数生成100个随机数看看

    public static void main(String[] args) {
    for(int j = 0; j< 100; j++){
    int i=(int)(Math.random()*1000000+100000);
    String messageCode = String.valueOf(i);
    System.out.println(messageCode);

    }
    }

    果然发现生成的随机数中,既有6位又有7位,奇怪,怎么跟自己的意愿不一样呢,接着,直接测试了下

    public static void main(String[] args) {
    for(int j = 0; j< 100; j++){
    System.out.println((Math.random()));
    }
    }

    生成的随机数尽然有0.0XXX的,我顿时迷惑了,赶快查了下文档,终于有所体会了,产生的随机数应该是0.0000...-1.00000...之间的,

    开始误认为是第一位非0的是就是位于小数点的后一位

    然后就只能根据测试的结果来重新信了个方法,测试了下确实是可以了

    public static void main(String[] args) {
    for(int j = 0; j< 100; j++){
    System.out.println((int)((Math.random()*9+1)*100000));
    }
    }




     

  • 相关阅读:
    【MySQL】全量+增量的备份/恢复
    【MySQL】MMM和MHA高可用架构
    【MySQL配置参数】sync_binlog和innodb_flush_log_at_trx_commit
    Redis2.8之后主从复制的流程
    docker push 出现:x509: certificate signed by unknown authority
    Ubuntu Docker版本的更新与安装
    CentOS7用阿里云Docker Yum源在线安装Docker
    Docker国内仓库和镜像
    Docker入门
    在centos和redhat上安装docker
  • 原文地址:https://www.cnblogs.com/shenliang123/p/2417798.html
Copyright © 2020-2023  润新知