java
原創,轉載需註明。
短8位UUID思想其實借鑑微博短域名的生成方式,可是其重複機率太高,並且每次生成4個,須要隨即選取一個。
本算法利用62個可打印字符,經過隨機生成32位UUID,因爲UUID都爲十六進制,因此將UUID分紅8組,每4個爲一組,而後經過模62操做,結果做爲索引取出字符,
這樣重複率大大下降。
經測試,在生成一千萬個數據也沒有出現重複,徹底知足大部分需求。
代碼貼出來供你們參考。
public static String[] chars = new String[] { "a", "b", "c", "d", "e", "f",
"g", "h", "i", "j", "k", "l", "m", "n", "o", "p", "q", "r", "s",
"t", "u", "v", "w", "x", "y", "z", "0", "1", "2", "3", "4", "5",
"6", "7", "8", "9", "A", "B", "C", "D", "E", "F", "G", "H", "I",
"J", "K", "L", "M", "N", "O", "P", "Q", "R", "S", "T", "U", "V",
"W", "X", "Y", "Z" };
public static String generateShortUuid() {
StringBuffer shortBuffer = new StringBuffer();
String uuid = UUID.randomUUID().toString().replace("-", "");
for (int i = 0; i < 8; i++) {
String str = uuid.substring(i * 4, i * 4 + 4);
int x = Integer.parseInt(str, 16);
shortBuffer.append(chars[x % 0x3E]);
}
return shortBuffer.toString();
}
---------------------
做者:andy_miao858
來源:CSDN
原文:https://blog.csdn.net/andy_miao858/article/details/9530245
版權聲明:本文爲博主原創文章,轉載請附上博文連接!
python
import uuid
array = ["a", "b", "c", "d", "e", "f",
"g", "h", "i", "j", "k", "l", "m", "n", "o", "p", "q", "r", "s",
"t", "u", "v", "w", "x", "y", "z", "0", "1", "2", "3", "4", "5",
"6", "7", "8", "9", "A", "B", "C", "D", "E", "F", "G", "H", "I",
"J", "K", "L", "M", "N", "O", "P", "Q", "R", "S", "T", "U", "V",
"W", "X", "Y", "Z"]
def get_short_id():
id = str(uuid.uuid4()).replace("-", '')
buffer = []
for i in range(0, 8):
start = i * 4
end = i * 4 + 4
val = int(id[start:end], 16)
buffer.append(array[val b])
return "".join(buffer)
for i in range(100):
print(get_short_id())