随机ID生成的几种 方式整理(现阶段基础)

简介: 随机ID生成的几种 方式整理(现阶段基础)

代码和注释都有大家根据自己需求自取即可;

package com.example.democrud.democurd.uuid;
import java.text.DateFormat;
import java.text.SimpleDateFormat;
import java.util.Date;
import java.util.Random;
import java.util.UUID;
public class uuid {
    public static void main(String[] args) {
        System.out.println("----------------------random随机数--------------------");
         //random随机数
         Random random = new Random();
         //取(10000-99999)的数,random出来0-89999的数,再加10000就达到效果。
         //3个8 代表获取的随机的值 是3位数的
         int id=random.nextInt(8888)+1000;
         System.out.println("random随机数==>"+id);
        UUID uuid = UUID.randomUUID();
        System.out.println("原生uuid==>"+uuid);
        System.out.println("----------------------UUID随机数 常用--------------------");
        String str = uuid.toString();
        String uuidStr = str.replace("-", "");
        System.out.println(uuidStr);
        System.out.println("----------------------UUID随机数 根据一个符合UUID格式的字符串获取--------------------");
        UUID uuid1 = UUID.fromString("095c64fe-c5bf-11ea-aec6-a402b9e2b04d");
        System.out.println(uuid1);
        System.out.println("----------------------UUID随机数 根据字符串获取--------------------");
        UUID uuid2 = UUID.nameUUIDFromBytes("身份证号码".getBytes());
        System.out.println(uuid2);
        UUID uuid21 = UUID.nameUUIDFromBytes("身份证号码".getBytes());
        System.out.println(uuid21);
        System.out.println("通过demo得出相同字符得除的加密是相同的");
        UUID uuid3 = UUID.nameUUIDFromBytes("身份证号码11".getBytes());
        System.out.println(uuid3);
        System.out.println("----------------------生成随机ID--------------------");
         //生成6位随机数字
        System.out.println((int)((Math.random()*9+1)*100000));
        //生成5位随机数字
        System.out.println((int)((Math.random()*9+1)*10000));
        //生成4位随机数字
        System.out.println((int)((Math.random()*9+1)*1000));
        //生成3位随机数字
        System.out.println((int)((Math.random()*9+1)*100));
        //生成2位随机数字
        System.out.println((int)((Math.random()*9+1)*10));
        //生成1位随机数字
        System.out.println((int)((Math.random()*9+1)));
        System.out.println("----------------------生成时间UUID随机数--------------------");
        Date date=new Date();
        DateFormat format = new SimpleDateFormat("yyyyMMdd");
        String time = format.format(date);
        int hashCodeV = UUID.randomUUID().toString().hashCode();
        if (hashCodeV < 0) {//有可能是负数
            hashCodeV = -hashCodeV;
        }
        // 0 代表前面补充0
        // 11 代表长度为11 时间后面值的长度,他的长度的增加与减少是靠增加0 与去掉0来处理的
        // d 代表参数为正数型
        System.out.println("当前时间年月日"+time);
        System.out.println(time + String.format("%011d", hashCodeV));
        // 13 代表长度为13 不足的需要增加0补充
        System.out.println(time + String.format("%013d", hashCodeV));
    }
}

运行结果如下:

----------------------random随机数--------------------
random随机数==>1289
原生uuid==>97bc24f0-d12e-4184-b970-46a34dd53f06
----------------------UUID随机数 常用--------------------
97bc24f0d12e4184b97046a34dd53f06
----------------------UUID随机数 根据一个符合UUID格式的字符串获取--------------------
095c64fe-c5bf-11ea-aec6-a402b9e2b04d
----------------------UUID随机数 根据字符串获取--------------------
84e0cb5d-57ed-395b-8cc0-4b4ab9a7997b
84e0cb5d-57ed-395b-8cc0-4b4ab9a7997b
通过demo得出相同字符得除的加密是相同的
4b5b1bc6-86d1-390e-af96-0acd922f308f
----------------------生成随机ID--------------------
112926
52122
9081
109
43
1
----------------------生成时间UUID随机数--------------------
当前时间年月日20230202
2023020200914093716
202302020000914093716

不足之处多多谅解;有其他更好的方式,欢迎留言;


相关文章
|
27天前
|
编译器 C++
我的C++奇迹之旅:值和引用的本质效率与性能比较1
我的C++奇迹之旅:值和引用的本质效率与性能比较
|
27天前
|
存储 分布式计算 安全
我的C++奇迹之旅:值和引用的本质效率与性能比较2
我的C++奇迹之旅:值和引用的本质效率与性能比较
|
2天前
|
机器学习/深度学习 人工智能 PyTorch
人工智能平台PAI 操作报错合集之机器学习PAI把SequenceFeature直接送入BST模块,但发现未配置sequence_combiner会报错,如何解决
阿里云人工智能平台PAI (Platform for Artificial Intelligence) 是阿里云推出的一套全面、易用的机器学习和深度学习平台,旨在帮助企业、开发者和数据科学家快速构建、训练、部署和管理人工智能模型。在使用阿里云人工智能平台PAI进行操作时,可能会遇到各种类型的错误。以下列举了一些常见的报错情况及其可能的原因和解决方法。
|
4月前
|
人工智能 算法 测试技术
【简历优化平台-03】轻字段信息的合理性及单独算法
【简历优化平台-03】轻字段信息的合理性及单独算法
|
9月前
|
计算机视觉
队列的概念及结构(内有成型代码可供CV工程师参考)
队列的概念及结构(内有成型代码可供CV工程师参考)
55 0
|
10月前
|
安全
项目实战典型案例19——临时解决方案和最终解决方案
项目实战典型案例19——临时解决方案和最终解决方案
75 0
|
10月前
|
监控
【项目实战典型案例】19.临时解决方案和最终解决方案
【项目实战典型案例】19.临时解决方案和最终解决方案
|
12月前
|
存储 JavaScript 前端开发
(小说版)【简历优化平台-3】随机唯一标识,贯穿时间长河
(小说版)【简历优化平台-3】随机唯一标识,贯穿时间长河
|
存储 算法 NoSQL
分布式 ID 生成方案总结整理
分布式 ID 生成方案总结整理
|
存储 监控 搜索推荐
我感受到的排序机制参考
假期重新把之前在新浪博客里面的文字梳理了下,搬到这里。这
133 0

热门文章

最新文章