JAVA 8 비트 UUID 생 성 실례 설명
이 알고리즘 은 62 개의 인쇄 가능 한 문 자 를 이용 하여 32 비트 UUID 를 무 작위 로 생 성 합 니 다.UUID 는 모두 16 진수 이기 때문에 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();
}
추가:8/16/32 비트 UUID 생 성나 는 더 이상 쓸데없는 말 을 하지 않 겠 으 니,모두들 직접 실례 를 보 는 것 이 좋 겠 다.
import java.util.UUID;
public class TestUUID {
// 16 UUID-( )
public static String getUUID_16() {
int machineId = 1;// 1-9
int hashCodeV = UUID.randomUUID().toString().hashCode();
if (hashCodeV < 0) {//
hashCodeV = -hashCodeV;
}
String string = machineId + String.format("%015d", hashCodeV);
return string;
}
// 32 UUID-( )
public static String getUUID_32() {
return UUID.randomUUID().toString().replace("-", "").toLowerCase();
}
// 8 UUID-( )
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 getUUID_8() {
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();
}
public static void main(String[] args) {
System.out.println(getUUID_8());
}
}
이상 은 개인 적 인 경험 이 므 로 여러분 에 게 참고 가 되 기 를 바 랍 니 다.여러분 들 도 저 희 를 많이 응원 해 주시 기 바 랍 니 다.만약 잘못 이 있 거나 완전히 고려 하지 않 은 부분 이 있다 면 아낌없이 가르침 을 주시 기 바 랍 니 다.
이 내용에 흥미가 있습니까?
현재 기사가 여러분의 문제를 해결하지 못하는 경우 AI 엔진은 머신러닝 분석(스마트 모델이 방금 만들어져 부정확한 경우가 있을 수 있음)을 통해 가장 유사한 기사를 추천합니다:
JAVA 객체 작성 및 제거 방법정적 공장 방법 정적 공장 방법의 장점 를 반환할 수 있습니다. 정적 공장 방법의 단점 류 공유되거나 보호된 구조기를 포함하지 않으면 이불류화할 수 없음 여러 개의 구조기 파라미터를 만났을 때 구축기를 고려해야 한다...
텍스트를 자유롭게 공유하거나 복사할 수 있습니다.하지만 이 문서의 URL은 참조 URL로 남겨 두십시오.
CC BY-SA 2.5, CC BY-SA 3.0 및 CC BY-SA 4.0에 따라 라이센스가 부여됩니다.