C# 中的随机数生成器是通过 System.Random
类实现的
-
种子(Seed):随机数生成器的初始值。它是一个整数,用于确定生成器的起始状态。种子相同时,生成的随机数序列也相同。如果不提供种子,
System.Random
将使用当前时间的毫秒数作为默认种子。 -
伪随机数生成算法:
System.Random
类使用一种称为线性同余方法(Linear Congruential Generator, LCG)的伪随机数生成算法。这种算法基于一个数学公式,在给定一个初始值(种子)的情况下,生成一系列看似随机的数字。LCG 算法的公式如下:Xn+1 = (aXn + c) % m
其中,Xn 是当前的随机数,Xn+1 是下一个随机数,a、c 和 m 是算法的常数参数。
-
数值范围:
System.Random
类提供了多种方法来生成不同范围内的随机数,例如:Next()
:生成一个非负整数。Next(int maxValue)
:生成一个介于 0(包含)和指定最大值(不包含)之间的非负整数。Next(int minValue, int maxValue)
:生成一个介于指定最小值(包含)和最大值(不包含)之间的整数。NextDouble()
:生成一个介于 0(包含)和 1(不包含)之间的双精度浮点数。
这些方法内部使用 LCG 算法生成的随机数,并根据所需的数值范围进行调整。
需要注意的是,System.Random
生成的随机数是伪随机数,因此在某些对随机性要求较高的场景(如密码学或安全应用)中,可能需要使用其他方法来生成真正的随机数。在这些场景中,可以考虑使用 System.Security.Cryptography.RandomNumberGenerator
类。