• JavaScript生成一个不重复的ID


    /**
     * 生成一个用不重复的ID
     */
    function GenNonDuplicateID():String{
      
    }
    

    先看看下面的几个方法

    1.生成[0,1)的随机数的Math.random,例如

    //我这次运行生成的是:0.5834165740043102
    Math.random()
    

    2.获取当前时间戳Date.now

    //现在时间戳是1482645606622
    Date.now() = 1521009303858
    

    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

    /**
     * 生成一个用不重复的ID
     */
    function GenNonDuplicateID(){
      return Math.random().toString(16)
    }
    
    //函数将生成类似 0.c1615913fa915 的ID
    GenNonDuplicateID()
    

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

    /**
     * 生成一个用不重复的ID
     */
    function GenNonDuplicateID(){
      return Math.random().toString(36)
    }
    
    //函数将生成类似 0.hefy7uw6ddzwidkwcmxkzkt9 的ID
    GenNonDuplicateID()
    

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

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

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

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

    /**
     * 生成一个用不重复的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

    /**
     * 生成一个用不重复的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

    /**
     * 生成一个用不重复的ID
     */
    function GenNonDuplicateID(randomLength){
      return Number(Math.random().toString().substr(3,randomLength) + Date.now()).toString(36)
    }
    //GenNonDuplicateID()将生成 rfmipbs8ag0kgkcogc 类似的ID
    GenNonDuplicateID()
    
  • 相关阅读:
    C语言 汉诺塔问题
    指向函数的指针 linux中常见的函数指针应用及函数指针数组
    C语言 折半/二分法查找
    C语言 stdlib.h自带函数库:qsort()排序,简称"快排"
    几种排序算法的稳定性归纳
    C语言 归并排序
    c语言 堆排序 多函数处理法
    C语言 递归方法实现快速排序
    C语言 通过输出排序次数来比较希尔排序和插入排序的优劣
    c语言 希尔排序简化函数版
  • 原文地址:https://www.cnblogs.com/alterem/p/11526463.html
Copyright © 2020-2023  润新知