悲催,老是记不住真随机数怎么写,次次翻项目笔记,更悲催的是,在外面还翻不了项目笔记。。。。。。
在这里记一份好了,顺便分享给不懂的朋友们。
伪随机数相关的东西都不写了,神马测试,数据,截图,通通省略。好吧,心软,给一点点。
跑一遍就知道什么是伪随机数了:
for (int i = 0; i < 1000; i++) { Console.WriteLine(new Random().Next(1, 1000)); }
随便扯两句:伪随机数之所以会重复,是因为随机数方法默认以时间为随机种子,而在编程里,时间精度终究有限,短时间内多次取出时间,这个时间值就可能重复,
时间(随机数种子)重复了,随机数自然也重复。所以我们的解决思路就是提供一个永不重复的随机数种子。
上代码:
获取强随机数种子
/// <summary> /// 描 述:创建加密随机数生成器 生成强随机种子 /// </summary> /// <returns></returns> static int GetRandomSeed() { byte[] bytes = new byte[4]; System.Security.Cryptography.RNGCryptoServiceProvider rng = new System.Security.Cryptography.RNGCryptoServiceProvider(); rng.GetBytes(bytes); return BitConverter.ToInt32(bytes, 0); }
使用方法:
int ranNumer = new Random(GetRandomSeed()).Next(numMin, numMax);
PS:方法二
刚刚说为什么会重复的时候,我突然想到,以时间为随机数种子,短时间内我不让它取那么多次,不就可以避免重复了?
试了一下:
for (int i = 0; i < 1000; i++) { Thread.Sleep(1);//强制停止一毫秒 Console.WriteLine(new Random().Next(1, 1000)); }
果然不重复了,我果真机智~~ *^_^*