zoukankan      html  css  js  c++  java
  • 随机数 JS

    /**
     * 生成一个用不重复的ID
     */
    function GenNonDuplicateID():String{
      
    }
    先看看下面的几个方法
    1.生成[0,1)的随机数的Math.random,例如
    //我这次运行生成的是:0.5834165740043102
    Math.random()
    2.获取当前时间戳Date.now
    //现在时间戳是1482645606622
    Date.now()
    3.将10进制转换为其他进制的字符串 Number.toString
    //将1482645606622转换成二进制:10101100100110100100100001001000011011110
    (1482645606622).toString(2)
    //转换成16进制:159349090de MongDB中的ObjectID就是24位16进制数
    (1482645606622).toString(16);
    //最大进制支持转为36进制,使用字符是0-9a-z :ix48wvry
    (1482645606622).toString(36)
    GenNonDuplicateID的自我进化
    1.随机数版本 v0.0.1
    /**
     * 生成一个用不重复的ID
     */
    function GenNonDuplicateID(){
     return Math.random().toString()
    }
     
    //生成一个类似 0.1283460319177394的ID
    GenNonDuplicateID()

    2.随机数版本16进制版本 v0.0.2

    1
    2
    3
    4
    5
    6
    7
    8
    /**
     * 生成一个用不重复的ID
     */
    function GenNonDuplicateID(){
     return Math.random().toString(16)
    }
    //函数将生成类似 0.c1615913fa915 的ID
    GenNonDuplicateID()

    3.随机数版本36进制版本 v0.0.3

    1
    2
    3
    4
    5
    6
    7
    8
    /**
     * 生成一个用不重复的ID
     */
    function GenNonDuplicateID(){
     return Math.random().toString(36)
    }
    //函数将生成类似 0.hefy7uw6ddzwidkwcmxkzkt9 的ID
    GenNonDuplicateID()

    4.随机数版本36进制版本 去掉"0." v0.0.4

    1
    2
    3
    4
    5
    6
    7
    8
    /**
     * 生成一个用不重复的ID
     */
    function GenNonDuplicateID(){
     return Math.random().toString(36).substr(3)
    }
    //函数将生成类似 8dlv9vabygks2cbg1spds4i 的ID
    GenNonDuplicateID()

    然而用一个随机数作为ID,随着使用次数的累积,必然会出现相同的两个ID

    5.引入时间戳 的36微进制版本 v0.1.1

    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    /**
     * 生成一个用不重复的ID
     */
    function GenNonDuplicateID(){
     let idStr = Date.now().toString(36)
     idStr += Math.random().toString(36).substr(3)
     return idStr
    }
    //函数将生成类似 ix49sfsnt7514k5wpflyb5l2vtok9y66r 的ID
    GenNonDuplicateID()

    6.引入时间戳 的36微进制版本 加入随机数长度控制 v0.1.2

    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    /**
     * 生成一个用不重复的ID
     */
    function GenNonDuplicateID(randomLength){
     let idStr = Date.now().toString(36)
     idStr += Math.random().toString(36).substr(3,randomLength)
     return idStr
    }
    // GenNonDuplicateID(3) 将生成类似 ix49wl2978w 的ID
    GenNonDuplicateID(3)

    这样生成的ID前面几位总是相同,看着不爽,于是再改改

    7. 引入时间戳 随机数前置 36进制 加入随机数长度控制 v0.1.3

    1
    2
    3
    4
    5
    6
    7
    8
    /**
     * 生成一个用不重复的ID
     */
    function GenNonDuplicateID(randomLength){
     return Number(Math.random().toString().substr(3,randomLength) + Date.now()).toString(36)
    }
    //GenNonDuplicateID()将生成 rfmipbs8ag0kgkcogc 类似的ID
    GenNonDuplicateID()
  • 相关阅读:
    << 和>> 的计算公式
    死锁面试题(什么是死锁,产生死锁的原因及必要条件)
    SpringBoot的注解:@SpringBootApplication注解 vs @EnableAutoConfiguration+@ComponentScan+@Configuration
    SpringBoot入门-15(springboot配置freemarker使用YML)
    shiro 登录
    springMVC RedirectAttributes
    IDEA3.5最新版激活码
    求递归算法时间复杂度:递归树
    渐进复杂度
    PL/SQL注册码
  • 原文地址:https://www.cnblogs.com/cherryblog/p/8408833.html
Copyright © 2011-2022 走看看