Sinh số ngẫu nhiên

Elixir:
Sinh số ngẫu nhiên

Làm sao:

Để sinh số ngẫu nhiên trong Elixir, bạn chủ yếu sử dụng module :rand mà cung cấp một số chức năng cho mục đích này. Dưới đây là hướng dẫn nhanh để bạn bắt đầu:

Đầu tiên, hãy chắc chắn bạn gieo hạt cho bộ sinh số ngẫu nhiên để khởi tạo nó với một điểm bắt đầu độc đáo:

:rand.seed(:exsplus)

Để tạo một số nguyên ngẫu nhiên trong một phạm vi, sử dụng:

random_integer = :rand.uniform(10) # Sinh một số giữa 1 và 10
IO.puts(random_integer)

Đối với một số thực ngẫu nhiên giữa 0 và 1.0:

random_float = :rand.uniform()
IO.puts(random_float)

Bạn có thể cần một phạm vi cụ thể hơn cho số thực, yêu cầu một chút tính toán thêm:

min = 1.5
max = 5.5
random_float_range = min + (:rand.uniform() * (max - min))
IO.puts(random_float_range)

Nhớ rằng, những con số này là ngẫu nhiên giả; chúng được xác định bởi hạt gieo và thuật toán nhưng đủ cho hầu hết các ứng dụng.

Sâu hơn

Khả năng sinh số ngẫu nhiên của Elixir dựa vào module :rand của Erlang, phản ánh di sản và mối quan hệ chặt chẽ với Erlang. Module :rand đã thay thế module :random cũ, cung cấp các thuật toán cải tiến cho việc sinh số ngẫu nhiên. Nó cung cấp một loạt các thuật toán, mặc định là exsplus, nhưng cũng hỗ trợ các thuật toán khác như exs64, exsl, và nhiều hơn nữa, mỗi thuật toán có ưu và nhược điểm về tốc độ và chất lượng ngẫu nhiên.

Một khía cạnh thú vị của việc sinh số ngẫu nhiên của Elixir (và do đó là của Erlang) là cách xử lý hạt gieo. Hệ thống duy trì các trạng thái hạt riêng biệt cho từng quá trình, đảm bảo rằng các quá trình đồng thời không can thiệp vào các chuỗi số ngẫu nhiên của nhau. Điều này đặc biệt hữu ích trong các ứng dụng đồng thời, đảm bảo tính dự đoán và độ tin cậy trong các hệ thống phân tán.

Dù module :rand đủ sử dụng cho hầu hết các trường hợp, các ứng dụng cần số ngẫu nhiên an toàn về mặt mật mã học nên xem xét các lựa chọn khác. Module crypto cung cấp các chức năng như crypto:strong_rand_bytes/1 được thiết kế để sinh dữ liệu ngẫu nhiên an toàn cho mục đích mật mã. Những lựa chọn thay thế này là cần thiết cho các ứng dụng nhạy cảm với an ninh như sinh token, mã hóa và một số loại cơ chế xác thực.