Random类默认的无参构造函数能够根据当前系统时钟为种子,进行一系列算法得出要求范围内的伪随机数算法
Random rd = new Random() rd.next(1,10)(生成1~10之间的随机数,不包括10)
这种随机数能够达到一些要求较低的目标,可是若是在高并发的状况下,Random类所取到的系统时钟种子接近甚至彻底同样,就颇有可能出现重复,这里用循环来举例并发
for(int i=0;i<10;i++) { Random rd = new Random(); Console.WriteLine(rd.Next(10,100).ToString()); }
这个例子会获得10个相同的随机数,应循环完成的时间是很是短,因此根据系统时间做为种子算出的随机数就会是同样的。因此Random循环只适用于要求比较低的状况。dom
2.Guid 类ide
System.Guid函数
GUID (Globally Unique Identifier) 全球惟一标识符高并发
GUID的计算使用到了不少在本机可取到的数字,如硬件的ID码,当前时间等.所计算出的128位整数(16字节)能够接近惟一的输出.ui
Console.WriteLine(Guid.NewGuid().ToString());
计算结果是xxxxxxxx-xxxx-xxxx-xxxx-xxxxxxxxxxxx结构的16进制数字.固然这个格式也是能够更改的.经常使用的四种格式:加密
var uuid = Guid.NewGuid().ToString(); // 9af7f46a-ea52-4aa3-b8c3-9fd484c2af12 var uuidN = Guid.NewGuid().ToString("N"); // e0a953c3ee6040eaa9fae2b667060e09 var uuidD = Guid.NewGuid().ToString("D"); // 9af7f46a-ea52-4aa3-b8c3-9fd484c2af12 var uuidB = Guid.NewGuid().ToString("B"); // {734fd453-a4f8-4c5d-9c98-3fe2d7079760} var uuidP = Guid.NewGuid().ToString("P"); // (ade24d16-db0f-40af-8794-1e08e2040df3) var uuidX = Guid.NewGuid().ToString("X"); // {0x3fa412e3,0x8356,0x428f,{0xaa,0x34,0xb7,0x40,0xda,0xaf,0x45,0x6f}}
3.RNGCryptoServiceProvider 类spa
System.Security.Cryptography.RNGCryptoServiceProvider code
RNGCryptoServiceProvider 使用加密服务提供程序 (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的计算较为繁琐,在循环中使用会消耗形成大量的系统资源开销,使用时需注意.
4.Membership.GeneratePassword()
Membership是一个方便快捷的进行角色权限管理的类,偶然发现一个颇有意思的方法,没研究过是如何实现的
public static string GeneratePassword(int length, int numberOfNonAlphanumericCharacters); // // 摘要: // 生成指定长度的随机密码。 // // 参数: // numberOfNonAlphanumericCharacters: // 生成的密码中的标点字符数。 // // length: // 生成的密码的字符数。长度必须介于 1 和 128 个字符之间。 // // 返回结果: // 指定长度的随机密码。
例:
for (int i = 0; i < 10; i++) { Response.Write(Membership.GeneratePassword(20, 1) + "<br>"); }
结果为
C!&^HoTNv3!ZHkK9BAbu
azLgER)JJ-UW8q*14yz*
I3qnb]Zxu16ht!kKZ!Q*
9U:MAQ&c1x)^aed@xe**
oL(%4JvfbP&t5*Hpl4l-
6@zj$CnhW&D+|xOf:qIk
A/!Di&l*tY$QaMH0gyzY
z^wu6{1BMq7D^+WU]>f$
1OgIJS3&09fw0F9.|aXA
8F+Gy+L{O6x{SfugME*%