C#中生成隨機數的幾種方法


  1. Random 類

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循環只適用於要求比較低的情況。

         2.Guid 類

System.Guid

GUID (Globally Unique Identifier) 全球唯一標識符

GUID的計算使用到了很多在本機可取到的數字,如硬件的ID碼,當前時間等.所計算出的128位整數(16字節)可以接近唯一的輸出.

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 類

System.Security.Cryptography.RNGCryptoServiceProvider 

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*%


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM