C# 如何生成一个随机数_C# 随机数生成方法详解

来源:这里教程网 时间:2026-02-21 17:29:26 作者:

C# 如何生成一个随机数? 最常用的方法是使用内置的

Random
类。它能生成整数、浮点数等类型的伪随机数,适用于大多数日常开发需求。下面详细介绍几种常见的随机数生成方式和注意事项。

使用 Random 类生成基本随机数

Random
类位于
System
命名空间中,创建其实例后即可调用方法生成随机数。

生成一个随机整数:
random.Next()
生成指定范围内的整数(包含最小值,不包含最大值):
random.Next(min, max)
生成随机小数(0.0 到 1.0 之间):
random.NextDouble()
生成非负随机浮点数:
random.NextSingle()
(.NET 6+)

示例代码:

Random random = new Random();
int randomNumber = random.Next();           // 任意整数
int rangeNumber = random.Next(1, 101);      // 1 到 100 之间的整数
double doubleValue = random.NextDouble();   // 0.0 ~ 1.0 之间的双精度数

避免重复种子导致的重复随机数

频繁创建

Random
实例可能导致生成相同的随机序列,因为默认以系统时间为种子。若在循环或高并发场景中连续创建实例,时间戳可能相同,从而产生重复值。

解决方法是将

Random
实例声明为静态或全局变量,复用同一个实例。

private static Random _random = new Random();
<p>public static int GetRandomNumber(int min, int max)
{
return _random.Next(min, max);
}

这样可避免因快速创建多个实例而导致的“看似不随机”问题。

线程安全的随机数生成

Random
类本身不是线程安全的。多线程环境下同时调用其方法可能导致异常或返回 0。

解决方案之一是使用

lock
锁定访问:

private static readonly Random _random = new Random();
private static readonly object _lock = new object();
<p>public static int GetThreadSafeRandom(int min, int max)
{
lock (_lock)
{
return _random.Next(min, max);
}
}

另一种更高效的方式是每个线程使用独立的

Random
实例,可通过
[ThreadStatic]
ThreadLocal<random></random>
实现。

需要更高安全性的场景:使用 RNGCryptoServiceProvider

如果用于密码、令牌等安全敏感场景,应使用加密级别的随机数生成器,如

RNGCryptoServiceProvider
或现代 .NET 中的
RandomNumberGenerator
类。

这类生成器基于系统熵源,更加安全,但性能较低,不适合高频调用。

using System.Security.Cryptography;
<p>public static int GetSecureRandom(int min, int max)
{
byte[] bytes = new byte[4];
using (var rng = RandomNumberGenerator.Create())
{
rng.GetBytes(bytes);
}
int result = Math.Abs(BitConverter.ToInt32(bytes, 0));
return min + (result % (max - min));
}

基本上就这些。普通场景用

Random
就够了,注意复用实例;高并发时加锁或使用线程本地存储;安全相关则选加密随机数生成器。掌握这些方法,就能灵活应对各种随机数需求了。

相关推荐