【C#】比较 Random 与 RandomNumberGenerator 生成随机字符串
程序员文章站
2023-03-15 20:01:56
生成随机数,第一反应肯定是 类,然而, 生成的随机数被称为伪随机数,因为用 生成随机数时,需要用到一个“种子”,而 使用相同的种子,一定会产生相同序列的数字 。 如果在创建 时没有提供种子,那么就将用当前系统时间来生成种子。 由于系统时钟只有有限的粒度,因此两个创建时间非常相近(一般在 10 毫秒之 ......
生成随机数,第一反应肯定是 random
类,然而,random
生成的随机数被称为伪随机数,因为用 random
生成随机数时,需要用到一个“种子”,而 使用相同的种子,一定会产生相同序列的数字。
random r1 = new random(1); console.writeline(r1.next(100)); // 24 random r2 = new random(1); console.writeline(r2.next(100)); // 24
如果在创建 random
时没有提供种子,那么就将用当前系统时间来生成种子。
由于系统时钟只有有限的粒度,因此两个创建时间非常相近(一般在 10 毫秒之内)的 random
实例会生成相同的值序列。
for (int i = 0; i < 10; i++) { random rd = new random(); console.writeline(rd.next(256)); }
结果:
43 2 2 2 2 2 2 2 2 2
可以看到,这个结果中有大量的重复值。
random
的随机性安全性并不高,而 randomnumbergenerator
是一种密码强度的随机数生成器。
var rand = system.security.cryptography.randomnumbergenerator.create(); byte[] bytes = new byte[32]; rand.getbytes(bytes);
字节数组的长度决定了生成的随机字节数。之后用 base64
转成字符串就可以了。