C#随机数生成 Random GUID RNG三种方法实现随机数,Random类随机数生成,GUID 全球唯一标识符随机数生成,RNG随机数生成,使用加密服务提供程序 (CSP) 提供的实现来实现加密随机数生成器 (RNG)。
1、Random类随机数生成
Random 类, int Next(int minValue, int maxValue),返回一个指定范围内的随机数。 返回的随机数的下界(随机数可取该下界值)。返回的随机数的上界(随机数不能取该上界值)。maxValue 必须大于或等于 minValue。
一个大于等于 minValue 且小于 maxValue 的 32 位带符号整数,即:返回的值范围包括 minValue 但不包括 maxValue。如果 minValue 等于 maxValue,则返回 minValue。
Random类默认的无参构造函数可以根据当前系统时钟为种子,进行一系列算法得出要求范围内的伪随机数
Random rd = new Random()
rd.next(1,10)(生成1~10之间的随机数,不包括10)
这种随机数可以达到一些要求较低的目标,但是如果在高并发的情况下,Random类所取到的系统时钟种子接近甚至完全一样,就很有可能出现重复,这里用循环来举例
这个例子会得到10个相同的随机数,应循环完成的时间是非常短,所以根据系统时间作为种子算出的随机数就会是一样的。所以Random循环只适用于要求比较低的情况。
Random rd = new Random() 放在for循环之外,这样就可以避免出现随机数相同的情况了。
2、GUID 全球唯一标识符随机数生成
GUID (Globally Unique Identifier) 全球唯一标识符,GUID的计算使用到了很多在本机可取到的数字,如硬件的ID码,当前时间等.所计算出的128位整数(16字节)可以接近唯一的输出.
Console.WriteLine(Guid.NewGuid().ToString());
计算结果是xxxxxxxx-xxxx-xxxx-xxxx-xxxxxxxxxxxx结构的16进制数字.当然这个格式也是可以更改的.常用的四种格式:
3、RNG随机数生成,使用加密服务提供程序 (CSP) 提供的实现来实现加密随机数生成器 (RNG)。
RNGCryptoServiceProvider csp = new RNGCryptoServiceProvider();
byte[] byteCsp = new byte[10];
csp.GetBytes(byteCsp);
Console.WriteLine(BitConverter.ToString(byteCsp));
因该类使用更严密的算法.所以即使如下放在循环中,所计算出的随机数也是不同的.
for (int i = 0; i < 10; i++)
{
RNGCryptoServiceProvider csp = new RNGCryptoServiceProvider();
byte[] byteCsp = new byte[10];
csp.GetBytes(byteCsp);
Console.WriteLine(BitConverter.ToString(byteCsp));
}
但是RNGCryptoServiceProvider的计算较为繁琐,在循环中使用会消耗造成大量的系统资源开销,使用时需注意。