0

0

C# 文件空洞(Sparse File)创建 C#如何创建稀疏文件以节省磁盘空间

畫卷琴夢

畫卷琴夢

发布时间:2026-02-05 09:33:01

|

370人浏览过

|

来源于php中文网

原创

稀疏文件是NTFS文件系统特性,C#无法直接创建但可通过P/Invoke调用CreateFile和DeviceIoControl启用SPARSE属性,并配合Seek跳写或SetFileValidData实现物理空间节省。

c# 文件空洞(sparse file)创建 c#如何创建稀疏文件以节省磁盘空间

什么是稀疏文件,C# 能直接创建吗

稀疏文件(Sparse File)本身是文件系统特性(NTFS 支持),不是 .NET 运行时原生抽象。C# 无法“直接创建稀疏文件”,但可以通过调用 Windows API CreateFileDeviceIoControl 启用稀疏属性,并配合 SetFileValidData 或跳过写零来实现逻辑上的稀疏布局。

关键点:必须在 NTFS 卷上操作;必须以 FILE_ATTRIBUTE_SPARSE 创建或设置;写入大量零时不实际占用磁盘空间,但读取仍返回零。

如何用 C# 启用文件的稀疏属性

启用稀疏属性需两步:先创建/打开文件句柄,再发送 FSCTL_SET_SPARSE 控制码。.NET 的 FileStream 不暴露该能力,必须用 P/Invoke。

  • 使用 CreateFile 打开文件,dwFlagsAndAttributes 参数传入 FILE_ATTRIBUTE_SPARSE(仅对新建文件有效)
  • 若文件已存在,需用 DeviceIoControl + FSCTL_SET_SPARSE 显式启用(否则忽略)
  • 调用前确保文件句柄有 GENERIC_WRITE 权限,且未被其他进程独占打开
  • 启用后,后续写入零区域不会分配磁盘簇——但注意:普通 FileStream.Write 写零仍会触发分配,必须配合 SetFileValidData 或 seek + write 非零数据来真正节省空间

C# 稀疏写入的实际操作方式

单纯设 sparse 属性不等于节省空间。真正省空间靠的是“跳过写零”,常见做法是:

Oreate AI
Oreate AI

面向学术写作与内容创作的一站式AI创作平台

下载
  • FileStream.Seek 跳到远端位置(如 10GB),再写几个字节——中间空洞由文件系统标记为未分配
  • 避免用 Write 往空洞里填零;若必须初始化大块区域,优先调用 SetFileValidData(需 SeManageVolumePrivilege 权限,且跳过零填充校验)
  • 检查是否生效:在资源管理器中看“大小”和“占用空间”是否明显不同;或用命令行 fsutil sparse queryflag testfile.bin
  • 示例片段:
    var h = CreateFile("data.bin", ... FILE_ATTRIBUTE_SPARSE ...);
    DeviceIoControl(h, FSCTL_SET_SPARSE, IntPtr.Zero, 0, IntPtr.Zero, 0, out _, IntPtr.Zero);
    var fs = new FileStream(h, FileAccess.Write);
    fs.Seek(0x100000000, SeekOrigin.Begin); // 跳到 4GB
    fs.WriteByte(0xFF); // 只写 1 字节 → 实际磁盘只占 1 个簇

容易踩的坑和权限问题

稀疏文件在 C# 中属于“半手动系统编程”,绕不开权限与行为陷阱:

  • SetFileValidData 需管理员权限 + SeManageVolumePrivilege,普通用户默认无权调用,否则返回 ERROR_PRIVILEGE_NOT_HELD
  • 启用 sparse 后,某些备份工具杀毒软件可能不兼容,误判为损坏或跳过空洞区域
  • Linux/Samba 共享挂载 NTFS 卷时,稀疏属性通常丢失;跨平台场景慎用
  • 文件复制(如 File.Copy)会把空洞展开为真实零字节,瞬间吃光磁盘——必须用 CopyFileEx 并指定 COPY_FILE_SPARSE 标志
  • 调试时别依赖 FileInfo.LengthFileInfo.Directory?.GetFiles() 的“大小”字段判断磁盘占用,它们都返回逻辑长度,不是物理占用

真正控制稀疏行为的始终是 Windows 文件系统层,C# 只是通道。任何想“自动稀疏化”的封装库,底层都绕不开这些 API 和权限校验。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
length函数用法
length函数用法

length函数用于返回指定字符串的字符数或字节数。可以用于计算字符串的长度,以便在查询和处理字符串数据时进行操作和判断。 需要注意的是length函数计算的是字符串的字符数,而不是字节数。对于多字节字符集,一个字符可能由多个字节组成。因此,length函数在计算字符串长度时会将多字节字符作为一个字符来计算。更多关于length函数的用法,大家可以阅读本专题下面的文章。

930

2023.09.19

length函数用法
length函数用法

length函数用于返回指定字符串的字符数或字节数。可以用于计算字符串的长度,以便在查询和处理字符串数据时进行操作和判断。 需要注意的是length函数计算的是字符串的字符数,而不是字节数。对于多字节字符集,一个字符可能由多个字节组成。因此,length函数在计算字符串长度时会将多字节字符作为一个字符来计算。更多关于length函数的用法,大家可以阅读本专题下面的文章。

930

2023.09.19

length函数用法
length函数用法

length函数用于返回指定字符串的字符数或字节数。可以用于计算字符串的长度,以便在查询和处理字符串数据时进行操作和判断。 需要注意的是length函数计算的是字符串的字符数,而不是字节数。对于多字节字符集,一个字符可能由多个字节组成。因此,length函数在计算字符串长度时会将多字节字符作为一个字符来计算。更多关于length函数的用法,大家可以阅读本专题下面的文章。

930

2023.09.19

windows查看端口占用情况
windows查看端口占用情况

Windows端口可以认为是计算机与外界通讯交流的出入口。逻辑意义上的端口一般是指TCP/IP协议中的端口,端口号的范围从0到65535,比如用于浏览网页服务的80端口,用于FTP服务的21端口等等。怎么查看windows端口占用情况呢?php中文网给大家带来了相关的教程以及文章,欢迎大家前来阅读学习。

929

2023.07.26

查看端口占用情况windows
查看端口占用情况windows

端口占用是指与端口关联的软件占用端口而使得其他应用程序无法使用这些端口,端口占用问题是计算机系统编程领域的一个常见问题,端口占用的根本原因可能是操作系统的一些错误,服务器也可能会出现端口占用问题。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

1136

2023.07.27

windows照片无法显示
windows照片无法显示

当我们尝试打开一张图片时,可能会出现一个错误提示,提示说"Windows照片查看器无法显示此图片,因为计算机上的可用内存不足",本专题为大家提供windows照片无法显示相关的文章,帮助大家解决该问题。

813

2023.08.01

windows查看端口被占用的情况
windows查看端口被占用的情况

windows查看端口被占用的情况的方法:1、使用Windows自带的资源监视器;2、使用命令提示符查看端口信息;3、使用任务管理器查看占用端口的进程。本专题为大家提供windows查看端口被占用的情况的相关的文章、下载、课程内容,供大家免费下载体验。

456

2023.08.02

windows无法访问共享电脑
windows无法访问共享电脑

在现代社会中,共享电脑是办公室和家庭的重要组成部分。然而,有时我们可能会遇到Windows无法访问共享电脑的问题。这个问题可能会导致数据无法共享,影响工作和生活的正常进行。php中文网给大家带来了相关的教程以及文章,欢迎大家前来阅读学习。

2355

2023.08.08

抖音网页版入口与视频观看指南 抖音官网视频在线访问
抖音网页版入口与视频观看指南 抖音官网视频在线访问

本专题汇总了抖音网页版的入口链接、官方登录页面以及视频观看入口,帮助用户快速访问抖音网页版,提供免登录访问方式和直接进入视频播放页面的方法,确保顺利浏览和观看抖音视频。

61

2026.02.04

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
PostgreSQL 教程
PostgreSQL 教程

共48课时 | 8.5万人学习

Git 教程
Git 教程

共21课时 | 3.3万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号