千鋒教育-做有情懷、有良心、有品質(zhì)的職業(yè)教育機(jī)構(gòu)

手機(jī)站
千鋒教育

千鋒學(xué)習(xí)站 | 隨時隨地免費學(xué)

千鋒教育

掃一掃進(jìn)入千鋒手機(jī)站

領(lǐng)取全套視頻
千鋒教育

關(guān)注千鋒學(xué)習(xí)站小程序
隨時隨地免費學(xué)習(xí)課程

當(dāng)前位置:首頁  >  技術(shù)干貨  > Java隨機(jī)數(shù)生成器 – 如何使用數(shù)學(xué)隨機(jī)()生成數(shù)字并轉(zhuǎn)換為整數(shù)

Java隨機(jī)數(shù)生成器 – 如何使用數(shù)學(xué)隨機(jī)()生成數(shù)字并轉(zhuǎn)換為整數(shù)

來源:千鋒教育
發(fā)布人:syq
時間: 2022-09-15 15:41:56 1663227716

  在許多應(yīng)用程序中,您需要隨機(jī)數(shù)。您可能需要在視頻游戲中擲骰子,創(chuàng)建私有加密密鑰或創(chuàng)建用戶的臨時密碼。

Java隨機(jī)數(shù)生成器

  所有這些應(yīng)用程序都依賴于隨機(jī)數(shù)的創(chuàng)建。有時很難區(qū)分何時使用什么,而安全性是一個深刻的話題。如果不花幾年時間深入研究它,就很難快速理解有關(guān)可用實現(xiàn)的文檔,并為您的用例選擇正確的方法。

  因此,在本教程中,我將總結(jié)突出的用例以及如何根據(jù)您的 Java 代碼選擇性能最佳的實現(xiàn)。

1

  在本文中,您將了解:

  如何生成整數(shù)、浮點數(shù)和布爾值,

  如何為性能關(guān)鍵型用例生成隨機(jī)數(shù),

  如何為安全關(guān)鍵用例生成隨機(jī)數(shù),

  數(shù)字生成器的工作原理,

  偽隨機(jī)數(shù)生成器和真隨機(jī)數(shù)生成器之間的差異,

  如何利用種子對你有利。

  所有代碼示例都是最小的,您可以在GitHub上找到完整的源代碼。

  數(shù)學(xué)約束隨機(jī)()

  Math.random甚至在Java 6之前就已經(jīng)存在了。它易于訪問,并且仍然被廣泛使用。在 Java 17 中,可以使用一個名為的新通用接口,該接口整合了當(dāng)前 Java SDK 中的所有隨機(jī)生成器實現(xiàn)。RandomGenerator

  Math.random()如今,只需將 權(quán)限委派給 .但是,它只返回一個 .因此,它不允許您請求不同類型的數(shù)字或在范圍之間生成數(shù)字。它也不允許你從不同的實現(xiàn)中進(jìn)行選擇。Random().nextFloat()double

  在以下各節(jié)中,您將了解更靈活的數(shù)字生成,并了解如何生成針對效率或安全性進(jìn)行優(yōu)化的數(shù)字。

  自 Java 17 以來的通用接口

  在 Java 17 中,通用接口由 Java SDK 中的可用數(shù)字生成器實現(xiàn)。您可以使用適用于所有基本數(shù)據(jù)類型的方法,并且可以定義要為其生成數(shù)字的預(yù)期范圍:

2

  單線程環(huán)境中的性能優(yōu)化隨機(jī)數(shù)生成

  對于許多與安全無關(guān)的情況,您并不關(guān)心隨機(jī)數(shù)的可預(yù)測性。通常,您只想擁有可靠的分布。

  與應(yīng)用程序是單線程時可用的實現(xiàn)相比,性能更高的實現(xiàn)。一種非常有效的替代方案稱為:RandomSplittableRandom

  new SplittableRandom().nextInt();

  在 MacBook Pro 上執(zhí)行的比較“可拆分隨機(jī)”和“隨機(jī)”的基準(zhǔn)測試顯示以下結(jié)果:

3

  SplittableRandom執(zhí)行速度比在單線程環(huán)境中快 5 倍。Random

  其他優(yōu)點是確定性行為和可拆分的分叉/連接實現(xiàn)??偠灾?,您應(yīng)該更喜歡在單線程環(huán)境中使用。Random()SplittableRandomRandom

  多線程環(huán)境中的性能優(yōu)化隨機(jī)數(shù)生成

  高吞吐量應(yīng)用程序利用多個線程。因此,您希望使用用于并行使用的數(shù)字生成器。

  的實現(xiàn)是線程安全的,但相對較慢,并且由于鎖定而減慢得更多。因為不是線程安全的,所以這里不是替代方案。RandomSplittableRandom

  但是,通過在多線程環(huán)境中使用,可以獲得更好的性能。它使用 ,但確保在多個線程中高性能且安全的使用:ThreadLocalRandomSplittableRandom

  ThreadLocalRandom.current().nextInt();

  在 MacBook Pro 上執(zhí)行的基準(zhǔn)測試使用 10 個線程比較線程本地隨機(jī)數(shù)和隨機(jī)生成數(shù),顯示以下結(jié)果:

4

  如您所見,使用速度提高了425倍。 是無鎖的,因此比線程安全類的性能更高。ThreadLocalRandomThreadLocalRandomRandom

  安全優(yōu)化的隨機(jī)數(shù)生成

  我們剛才討論的方法對于您的大多數(shù)應(yīng)用程序來說都是快速且足夠的。但是,他們正在創(chuàng)建所謂的偽隨機(jī)生成的數(shù)字。

  他們不是總是創(chuàng)建一個真正的隨機(jī)數(shù),而是根據(jù)先前預(yù)測的數(shù)字預(yù)測一個新數(shù)字,這伴隨著一個狀態(tài)和嚴(yán)重的可預(yù)測性問題。

  也許您想為加密創(chuàng)建長期存在的機(jī)密,并且您不希望其他人能夠預(yù)測下一個生成的令牌。

  在Java中,對于更多與安全性相關(guān)的用例::SecureRandom

  SecureRandom.getInstanceStrong().nextInt();

  SecureRandom.getInstanceStrong()為您提供一個提供程序,用于創(chuàng)建安全令牌。在許多 Linux 系統(tǒng)中,您使用 ,根據(jù)真實設(shè)備的隨機(jī)噪聲生成數(shù)字。/dev/random

  但是,如果您沒有收集足夠的隨機(jī)數(shù)據(jù),即所謂的缺失熵,則執(zhí)行可能會阻塞并花費意外的長時間。特別是在具有大量 Docker 容器的機(jī)器中,這可能會導(dǎo)致在實踐中執(zhí)行緩慢。

  作為替代方法,在沒有熵可用的情況下,默認(rèn)情況下不阻塞。它還使用不太安全的數(shù)字生成方式作為回退。new SecureRandom()

  如何利用種子發(fā)揮您的優(yōu)勢

  默認(rèn)情況下,偽數(shù)生成器使用隨機(jī)種子,該種子反映用于生成值的起始值。因此,種子對于測試非常方便,因為它使您可以控制預(yù)測并允許您重置數(shù)字的創(chuàng)建方式。

  到目前為止,我們還沒有談?wù)撨^與種子有關(guān)的任何事情。

5

  這使得測試變得容易得多。否則,您需要始終模擬依賴項。

  為什么數(shù)字生成很難

  了解為什么數(shù)字生成很難獲得安全感至關(guān)重要。

  工程師編寫代碼,最終編譯成在實際處理單元(CPU)中執(zhí)行的機(jī)器可讀代碼。CPU建立在電子電路上,電子電路由邏輯門組成。

  長話短說,沒有真正的隨機(jī)性,你可以用傳統(tǒng)計算機(jī)創(chuàng)建,因為輸出需要一些輸入,根據(jù)定義,這不可能是隨機(jī)的。

  這意味著您需要來自現(xiàn)實世界的某種真正的隨機(jī)輸入,例如來自電阻器的熱噪聲。有一些昂貴的硬件數(shù)字生成器使用現(xiàn)實世界的物理原理來為您提供大量的隨機(jī)數(shù)創(chuàng)建容量。

  不安全隨機(jī)數(shù)生成的風(fēng)險

  盡管許多協(xié)議在設(shè)計上是安全的,但如果攻擊者可以預(yù)測加密密鑰,則它們不是。

  如今,許多應(yīng)用程序都需要在幕后生成真正的隨機(jī)數(shù)。否則,攻擊者可能能夠預(yù)測生成的數(shù)字,并通過這樣做滲透到應(yīng)用程序中。

  例如,如果攻擊者突然可以立即解決加密問題,那么基于量子計算的安全相關(guān)處理突破可能是一個真正的威脅。

  在這篇博客文章中,您學(xué)習(xí)了如何在 Java 中有效地生成數(shù)字。您還學(xué)習(xí)了如何優(yōu)化性能或安全性,并了解了種子是什么以及如何使用它。

  此外,您現(xiàn)在應(yīng)該了解偽生成數(shù)和真隨機(jī)生成數(shù)之間的主要區(qū)別,并且應(yīng)該能夠描述為什么安全隨機(jī)數(shù)生成很重要。

tags:
聲明:本站稿件版權(quán)均屬千鋒教育所有,未經(jīng)許可不得擅自轉(zhuǎn)載。
10年以上業(yè)內(nèi)強(qiáng)師集結(jié),手把手帶你蛻變精英
請您保持通訊暢通,專屬學(xué)習(xí)老師24小時內(nèi)將與您1V1溝通
免費領(lǐng)取
今日已有369人領(lǐng)取成功
劉同學(xué) 138****2860 剛剛成功領(lǐng)取
王同學(xué) 131****2015 剛剛成功領(lǐng)取
張同學(xué) 133****4652 剛剛成功領(lǐng)取
李同學(xué) 135****8607 剛剛成功領(lǐng)取
楊同學(xué) 132****5667 剛剛成功領(lǐng)取
岳同學(xué) 134****6652 剛剛成功領(lǐng)取
梁同學(xué) 157****2950 剛剛成功領(lǐng)取
劉同學(xué) 189****1015 剛剛成功領(lǐng)取
張同學(xué) 155****4678 剛剛成功領(lǐng)取
鄒同學(xué) 139****2907 剛剛成功領(lǐng)取
董同學(xué) 138****2867 剛剛成功領(lǐng)取
周同學(xué) 136****3602 剛剛成功領(lǐng)取
相關(guān)推薦HOT
抖店入駐收費多少?開抖店費用是多少?

如果要開通抖音小店,需要先把抖音賬號開通商品櫥窗功能。入駐之后,可以選擇頭條賬號、抖音賬號、火山賬號任一類型注冊或登錄。那開個抖店要多...詳情>>

2023-09-19 07:50:26
想做直播帶貨的貨源哪里來?怎么找貨源?

現(xiàn)如今直播推廣的方式是非?;鸬模兄浅6嗟馁u家都是利用直播推廣店鋪產(chǎn)品,效果也是非常不錯。但很多賣家想要了解現(xiàn)在直播帶貨的話什么產(chǎn)品...詳情>>

2023-09-19 07:47:16
適合三農(nóng)領(lǐng)域的名字?有何技巧?

現(xiàn)在在抖音上很多博主會選擇直播來賺取更多的流量以及利潤,直播間的東西也有很多讓消費者信任并且喜歡的,而且隨著越來越多人直播,很多農(nóng)產(chǎn)品...詳情>>

2023-09-19 07:06:05
抖店商品發(fā)布違規(guī)怎么申訴?有何規(guī)則?

抖店服務(wù)市場服務(wù)商發(fā)布違禁信息如何處理?情節(jié)嚴(yán)重程度判定原則:違規(guī)嚴(yán)重等級主要通過服務(wù)商違規(guī)次數(shù)、造成后果的嚴(yán)重程度、獲利或?qū)е聯(lián)p失的...詳情>>

2023-09-19 06:59:55
“泛垂直起號”可能是2023年最高效的起號方式

這可能是明年最好用的旗號方式了,今天教大家一個很野,但是可以讓你三天漲1000粉的偏方。去年前年啊,每個人都教你,誰知七號對著自己的產(chǎn)品拍...詳情>>

2023-09-19 06:37:38
開班信息
北京校區(qū)
  • 北京校區(qū)
  • 大連校區(qū)
  • 廣州校區(qū)
  • 成都校區(qū)
  • 杭州校區(qū)
  • 長沙校區(qū)
  • 合肥校區(qū)
  • 南京校區(qū)
  • 上海校區(qū)
  • 深圳校區(qū)
  • 武漢校區(qū)
  • 鄭州校區(qū)
  • 西安校區(qū)
  • 青島校區(qū)
  • 重慶校區(qū)
  • 太原校區(qū)
  • 沈陽校區(qū)
  • 南昌校區(qū)
  • 哈爾濱校區(qū)