1 // 发现资产主键 2 @Id 3 @GeneratedValue(generator="system-uuid") 4 @GenericGenerator(name="system-uuid",strategy="uuid") 5 private Long id;
GUID是一个128位长的数字,一般用16进制表示。算法的核心思想是结合机器的网卡、当地时间、一个随即数来生成GUID。从理论上讲,如果一台机器每秒产生10000000个GUID,则可以保证(概率意义上)3240年不重复。
UUID是1.5中新增的一个类,在java.util下,用它可以产生一个号称全球唯一的ID
UUID(Universally Unique Identifier)全局唯一标识符,是指在一台机器上生成的数字,它保证对在同一时空中的所有机器 都是唯一的。按照开放软件基金会(OSF)制定的标准计算,用到了以太网卡地址、纳秒级时间、芯片ID码和许多可能的数字。由以下几部分的组合:当前日期 和时间(UUID的第一个部分与时间有关,如果你在生成一个UUID之后,过几秒又生成一个UUID,则第一个部分不同,其余相同),时钟序列,全局唯一 的IEEE机器识别号(如果有网卡,从网卡获得,没有网卡以其他方式获得),UUID的唯一缺陷在于生成的结果串会比较长。
1 //4cdbc040-657a-4847-b266-7e31d9e2c3d9 2 for(int i=0;i<5;i++){ 3 UUID uuid = UUID.randomUUID(); 4 String str = uuid.toString(); 5 // 删除uuid中的"-" 6 String temp = str.substring(0, 8) + str.substring(9, 13) + str.substring(14, 18) + str.substring(19, 23) + str.substring(24); 7 //System.out.println(str +" ====" + temp + " uuid.hashCode() --> " + uuid.hashCode()); 8 // 获取uuid 的hashcode 9 int a = uuid.hashCode(); 10 // hashcode 的绝对值 因为uuid的hashcode可能为负数 11 int b = Math.abs(a); 12 System.out.println(a + " ========== " +b); 13 }