SORU
28 Kasım 2008, Cuma


Çarpışma Java bir UUID en önemli bit kullanma olasılığı

Long uuid = UUID.randomUUID().getMostSignificantBits() kullanıyorsam ne kadar muhtemel bir çarpışma olacak. Bir çarpışma içine çalışan bir ihtimal var yani en az önemli bit kesilir, değil mi?

CEVAP
28 Kasım 2008, Cuma


the documentation statik yöntemine göre UUID.randomUUID() tip 4 UUID üretir.

Bu altı bit bazı tür bilgi için kullanılır ve kalan 122 bit rasgele olduğu anlamına gelir.

Rastgele olmayan altı bit UUID en önemli yarısında dört ile dağıtılır ve en az önemli olan ikiye iki. Bu yüzden en önemli yarısı senin UUID içeren 60 bit Turk, sende de ortalama ihtiyaç oluşturmak 2^30 olacak biçimde bir çarpışma (göre 2^61 tam UUID).

Oldukça güvenli olduğunu söyleyebilirim. Bu kesinlikle Carl Seleborg bahseder gibi olacak biçimde, diğer türler için geçerli değildir unutmayın.

Bu arada, UUID en önemli yarısı (veya sadece uzun kullanarak rasgele bir SecureRandom üreten) kullanarak kapalı biraz daha iyi olurdu.

Bunu Paylaş:
  • Google+
  • E-Posta
Etiketler:

YORUMLAR

SPONSOR VİDEO

Rastgele Yazarlar

  • circuschina

    circuschina

    16 Mart 2007
  • Garrett Müller

    Garrett Mül

    26 HAZİRAN 2009
  • ICON

    ICON

    19 EKİM 2011