<p>DriveInfo.GetDrives() 是 Windows 下 C# 获取所有盘符最直接、标准且无需管理员权限的方式,返回 DriveInfo[],但必须检查 IsReady 与 DriveType 才能安全访问属性。</p>

用 DriveInfo.GetDrives() 获取所有盘符最直接
Windows 下 C# 列出所有磁盘驱动器,DriveInfo.GetDrives() 是标准且可靠的方式。它返回 DriveInfo[],每个元素对应一个物理或逻辑驱动器(包括光驱、U 盘、网络映射盘等),不依赖 WMI 或外部命令,也不需要管理员权限。
常见错误是调用后直接访问 .Name 或 .RootDirectory 却没检查 .IsReady,导致抛出 IOException(比如光驱无盘、U 盘被拔出)。
- 只取
drive.IsReady == true的驱动器,才能安全读取容量、文件系统等信息 -
drive.Name返回带冒号的盘符路径,如"C:";若只要字母,用drive.Name[0] - 网络驱动器(如
"Z:")可能返回DriveType.Network,但IsReady为false(服务器不可达时)
过滤掉无效或不可用驱动器很关键
不是所有 GetDrives() 返回的盘符都“能用”。比如空光驱、未格式化的 SD 卡、断开的网络映射盘,访问其属性会直接报错。生产环境里漏掉这步,程序很容易在用户机器上崩溃。
典型错误现象:System.IO.IOException: 设备未就绪 —— 就是试图读 drive.TotalSize 时触发的。
- 必须先判断
drive.IsReady,再访问TotalSize、AvailableFreeSpace、DriveFormat - 跳过
DriveType.Unknown和DriveType.NoRootDirectory(某些虚拟设备或损坏卷) - 如果只想要本地固定硬盘,筛选
drive.DriveType == DriveType.Fixed;U 盘用Removable
注意 .NET 版本对 UNC 路径和挂载点的支持差异
.NET Framework 4.7.2+ 和 .NET 5+ 对 Windows 挂载点(如 C:mountdisk2)和符号链接盘符支持更好;旧版本可能只返回传统盘符,漏掉这些路径。
另外,GetDrives() 不返回纯 UNC 路径(如 \servershare),它只处理有盘符映射的网络驱动器。没映射的共享路径不属于“驱动器”,得用其他方式枚举(如 NetServerEnum 或 Directory.GetDirectories 配合 SMB 探测)。
- 在 .NET Core/.NET 5+ 中,
DriveInfo行为与 Framework 基本一致,但某些挂载点识别更稳定 - 不要指望
GetDrives()返回 “D:data” 这类挂载点作为独立驱动器——它只认盘符根目录(D:) - 若需枚举所有挂载点,得结合
Win32_VolumeWMI 类或解析mountvol命令输出
简单安全的获取盘符列表代码模板
下面这段代码能跑在 .NET 6+,只取可用的本地盘符字母,不抛异常:
var drives = DriveInfo.GetDrives()
.Where(d => d.IsReady && d.DriveType == DriveType.Fixed)
.Select(d => d.Name[0])
.ToArray(); // 得到 char[],如 ['C', 'D']如果还要兼容可移动设备,把 DriveType.Fixed 改成 DriveType.Fixed || d.DriveType == DriveType.Removable;但务必保留 d.IsReady 判断。
真正容易被忽略的是:不同用户登录时,映射的网络驱动器可能不同;服务账户下甚至看不到用户映射的盘符——GetDrives() 返回结果取决于当前运行上下文的 session,不是全局物理设备列表。











