如果你做個實驗
復制代碼 代碼如下:
for (int i = 0; i > 100; i++)
{
Console.WriteLine(new Random(i).Next());
}
就會看到很有規律的一串數
許多人想到時間,DateTime.Now.Ticks,首先這個屬性是long,與Random構造函數的參數不符,你需要做一定處理,而且在機器很快的情況下,短時間內這個數字不會有變化,生成的“隨機數”也就都是一樣的。於是網上介紹的許多方法會用Ticks相乘、或者乘以i等做一些處理,讓這個種子看上去隨機一些,不過還是顯得麻煩。
其實,在.Net中,說道隨機,最先想到的就是Guid.NewGuid(),但Guid是Guid的格式,怎麼轉換成你自己的格式呢?
HashCode!
.Net中,所有類繼承於object,而所有的object都會有Equals()和GetHashCode()兩個方法,而GetHashCode()的返回值,正是Random類構造函數所需要的int,這麼方便的東西,我們當然要利用一下,所以,很容易寫下了如下代碼。
復制代碼 代碼如下:
static string GetCode(int num)
{
string a = "ABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789";
StringBuilder sb = new StringBuilder();
for(int i = 0; i < num; i++)
{
sb.Append(a[new Random(Guid.NewGuid().GetHashCode()).Next(0, a.Length -1)]);
}
return sb.ToString();
}