C# I/O 核心用法
在 C# 中,输入输出(I/O)操作是处理文件、目录、流等数据交互的核心功能。本文将从基础到高级,系统讲解 C# 中文件 I/O 的实现方式、最佳实践及常见场景解决方案。
一、核心类与命名空间
1、System.IO 命名空间,包含以下关键类:
- File:静态方法实现文件的创建、读写、删除等。
- Directory:操作目录(创建、遍历、删除)。
- Path:安全处理文件路径(跨平台兼容)。
- FileStream:提供字节级别的文件读写。
- StreamReader/StreamWriter:封装流,支持文本编码处理。
- FileInfo/DirectoryInfo:实例方法操作文件或目录属性。
2、其他相关命名空间
- System.IO.Compression:处理 ZIP 压缩文件(如 ZipFile 类)。
- System.Text.Encoding:定义文本编码(如 UTF-8、GB2312)。
二、文件读写操作
1. 文本文件读写
- 快速读写(适合小文件)
使用 File 类的静态方法:
// 读取全部内容
string content = File.ReadAllText("file.txt", Encoding.UTF8);// 写入内容(覆盖)
File.WriteAllText("file.txt", "Hello World");// 追加内容
File.AppendAllText("file.txt", "\nNew Line");
- 流式读写(适合大文件或逐行处理)
使用 StreamReader 和 StreamWriter:
// 逐行读取大文件
using (var reader = new StreamReader("largefile.txt"))
{string line;while ((line = reader.ReadLine()) != null){Console.WriteLine(line);}
}// 流式写入
using (var writer = new StreamWriter("output.txt", append: true))
{writer.WriteLine("Line 1");writer.WriteLine("Line 2");
}
2. 二进制文件读写
使用 FileStream 直接操作字节:
// 写入二进制数据
byte[] data = new byte[] { 0x01, 0x02, 0x03 };
using (var stream = new FileStream("data.bin", FileMode.Create))
{stream.Write(data, 0, data.Length);
}// 读取二进制数据
byte[] buffer = new byte[1024];
using (var stream = new FileStream("data.bin", FileMode.Open))
{int bytesRead = stream.Read(buffer, 0, buffer.Length);
}
三、流(Stream)的核心概念
1. 流的分类
- FileStream:处理文件流。
- MemoryStream:在内存中操作数据。
- NetworkStream:网络数据传输(如 TCP/IP)。
2. 流的通用操作
using (FileStream fs = new FileStream("file.txt", FileMode.Open, FileAccess.Read))
{// 设置流位置(支持随机访问)fs.Seek(10, SeekOrigin.Begin);// 读取字节byte[] buffer = new byte[1024];int bytesRead = fs.Read(buffer, 0, buffer.Length);
}
3. 缓冲区的优化
- 通过指定缓冲区大小提升性能:
using (var fs = new FileStream("file.txt", FileMode.Open, FileAccess.Read, FileShare.Read, bufferSize: 4096))
{// 更高效的读写操作
}
四、异步 I/O 操作
- 使用 async/await 避免阻塞主线程:
// 异步读取文件
public async Task<string> ReadFileAsync(string path)
{using (var reader = new StreamReader(path)){return await reader.ReadToEndAsync();}
}// 异步写入文件
public async Task WriteFileAsync(string path, string content)
{using (var writer = new StreamWriter(path)){await writer.WriteAsync(content);}
}
五、目录与路径操作
1. 目录管理
// 创建目录(自动忽略已存在)
Directory.CreateDirectory(@"C:\data\logs");// 遍历所有文件
foreach (string file in Directory.EnumerateFiles(@"C:\data", "*.txt", SearchOption.AllDirectories))
{Console.WriteLine(file);
}// 删除目录(递归删除)
Directory.Delete(@"C:\data\logs", recursive: true);
2. 安全路径处理
// 合并路径(自动处理平台分隔符)
string path = Path.Combine("folder", "sub", "file.txt"); // 输出:folder/sub/file.txt// 获取文件名或扩展名
string fileName = Path.GetFileName(path); // file.txt
string ext = Path.GetExtension(path); // .txt
六、异常处理与调试
1. 常见异常类型
| 异常类型 | 触发场景 |
|---|---|
| FileNotFoundException | 文件不存在 |
| DirectoryNotFoundException | 目录不存在 |
| UnauthorizedAccessException | 无权限访问文件或目录 |
| IOException | 文件被占用、磁盘已满或路径过长 |
2. 健壮的异常处理
try
{string content = File.ReadAllText("config.json");
}
catch (FileNotFoundException ex)
{Console.WriteLine($"文件未找到: {ex.Message}");
}
catch (IOException ex)
{Console.WriteLine($"IO错误: {ex.Message}");
}
finally
{// 清理资源(如关闭数据库连接)
}
七、性能优化与最佳实践
1. 大文件处理
- 使用流式读写:避免一次性加载大文件到内存。
- 设置缓冲区大小:通过 FileStream 的 bufferSize 参数优化读写速度。
2. 安全性
- 验证用户输入路径:防止路径遍历攻击(如 …/…/…/)。
string userInput = "userfile.txt";
string safePath = Path.Combine(AppDomain.CurrentDomain.BaseDirectory, userInput);
- 限制文件访问权限:使用 File.GetAccessControl 管理 ACL。
3. 资源释放
- 始终使用 using 语句:确保流、读写器等资源被及时释放。
using (var stream = new FileStream("file.txt", FileMode.Open))
{// 操作流
} // 自动调用 stream.Dispose()
八、高级主题
1. 内存映射文件(Memory-Mapped Files)
高效处理超大文件或进程间共享数据:
using (var mmf = MemoryMappedFile.CreateFromFile("hugefile.bin"))
{using (var accessor = mmf.CreateViewAccessor()){// 直接操作内存映射区域accessor.Write(0, 123); // 写入整数int value = accessor.ReadInt32(0);}
}
2. 文件监控(FileSystemWatcher)
实时监控文件或目录变化:
var watcher = new FileSystemWatcher(@"C:\data");
watcher.Filter = "*.txt";
watcher.EnableRaisingEvents = true;watcher.Changed += (sender, e) =>
{Console.WriteLine($"文件 {e.Name} 被修改!");
};
3. 文件压缩与解压
使用 System.IO.Compression 处理 ZIP 文件:
// 创建 ZIP 文件
ZipFile.CreateFromDirectory(@"C:\data", @"C:\archive.zip");// 解压 ZIP 文件
ZipFile.ExtractToDirectory(@"C:\archive.zip", @"C:\extracted");
九、完整示例:文件加密与解密
using System.Security.Cryptography;
using System.Text;public class FileEncryptor
{public static void EncryptFile(string inputFile, string outputFile, string password){using (var aes = Aes.Create()){byte[] key = SHA256.Create().ComputeHash(Encoding.UTF8.GetBytes(password));byte[] iv = aes.IV;// 写入 IV 到输出文件using (var outputStream = new FileStream(outputFile, FileMode.Create)){outputStream.Write(iv, 0, iv.Length);// 加密数据using (var cryptoStream = new CryptoStream(outputStream, aes.CreateEncryptor(key, iv), CryptoStreamMode.Write))using (var inputStream = File.OpenRead(inputFile)){inputStream.CopyTo(cryptoStream);}}}}public static void DecryptFile(string inputFile, string outputFile, string password){using (var aes = Aes.Create()){byte[] key = SHA256.Create().ComputeHash(Encoding.UTF8.GetBytes(password));// 读取 IVusing (var inputStream = new FileStream(inputFile, FileMode.Open)){byte[] iv = new byte[aes.IV.Length];inputStream.Read(iv, 0, iv.Length);// 解密数据using (var cryptoStream = new CryptoStream(inputStream, aes.CreateDecryptor(key, iv), CryptoStreamMode.Read))using (var outputStream = new FileStream(outputFile, FileMode.Create)){cryptoStream.CopyTo(outputStream);}}}}
}
十、总结
1、核心原则
- 资源管理:使用 using 或 try/finally 确保资源释放。
- 异常处理:捕获特定异常,避免程序崩溃。
- 性能优化:流式处理大文件,异步避免阻塞。
2、适用场景
- 简单操作:优先使用 File 的静态方法。
- 复杂控制:使用 FileStream 或 MemoryMappedFile。
- 跨平台:通过 Path.Combine 处理路径分隔符。
掌握这些内容后,可以高效处理各类文件 I/O 需求,并规避常见陷阱。
相关文章:
C# I/O 核心用法
在 C# 中,输入输出(I/O)操作是处理文件、目录、流等数据交互的核心功能。本文将从基础到高级,系统讲解 C# 中文件 I/O 的实现方式、最佳实践及常见场景解决方案。 一、核心类与命名空间 1、System.IO 命名空间,…...
SpringBoot之如何集成SpringDoc最详细文档
文章目录 一、概念解释1、OpenAPI2、Swagger3、Springfox4、Springdoc5. 关系与区别 二、SpringDoc基本使用1、导包2、正常编写代码,不需要任何注解3、运行后访问下面的链接即可 三、SpringDoc进阶使用1、配置文档信息2、配置文档分组3、springdoc的配置参数**1. 基…...
Oracle 数据迁移至 GaussDB 注意事项
将数据从 Oracle 迁移到 GaussDB(华为分布式数据库)时,需充分考虑架构差异、语法兼容性、数据一致性等核心问题。以下是关键注意事项及操作建议: 一、迁移前的准备工作 兼容性评估 语法差异:Oracle 使用 PL/SQL&#x…...
【智能体】| 知识库、RAG概念区分以及智能体是什么
文章目录 前言简介大模型“幻觉”问题如何解决“幻觉”问题? RAG、智能体、RAG智能体概念什么是检索增强型生成(RAG)模拟简单的RAG场景 AI系统中的智能体是什么什么是Agentic RAG?Agentic RAG如何工作?Agentic RAG架构…...
二分查找的应用
什么时候用二分查找? 数据具有二段性的时候 第一题: 题解代码: class Solution { public:int search(vector<int>& nums, int target) {int left 0,right nums.size()-1;while(left<right){int mid left (right-left)/2;//中…...
Android Compose 框架基础按钮模块深度剖析(四)
Android Compose 框架基础按钮模块深度剖析 一、引言 在现代 Android 应用开发中,Android Compose 框架以其声明式编程范式和简洁高效的开发体验,逐渐成为开发者构建用户界面的首选。而注解在 Android Compose 框架中扮演着至关重要的角色,…...
redis搭建一主一从+keepalived(虚拟IP)实现高可用
redis搭建一主一从keepalived(虚拟IP)实现高可用 前提 有两台机器:如 10.50.3.141 10.50.3.142,虚拟ip如:10.50.3.170 安装redis(两台机器执行): # 启用Remi仓库(CentOS 7) sudo yum install…...
【Function】Azure Function通过托管身份或访问令牌连接Azure SQL数据库
【Function】Azure Function通过托管身份或访问令牌连接Azure SQL数据库 推荐超级课程: 本地离线DeepSeek AI方案部署实战教程【完全版】Docker快速入门到精通Kubernetes入门到大师通关课AWS云服务快速入门实战目录 【Function】Azure Function通过托管身份或访问令牌连接Azu…...
MySQL日志全解析:类型、用途与运维实践
引言 MySQL作为最流行的关系型数据库之一,其日志系统是运维人员理解数据库状态、排查问题、保证数据安全的核心工具。不同类型的日志记录了数据库活动、错误信息、数据变更等关键内容。本文将深入解析MySQL各类日志的作用、配置参数及运维注意事项,帮助…...
《算法笔记》9.2小节——数据结构专题(2)->二叉树的遍历 问题 A: 复原二叉树(同问题 C: 二叉树遍历)
题目描述 小明在做数据结构的作业,其中一题是给你一棵二叉树的前序遍历和中序遍历结果,要求你写出这棵二叉树的后序遍历结果。 输入 输入包含多组测试数据。每组输入包含两个字符串,分别表示二叉树的前序遍历和中序遍历结果。每个字符串由…...
小程序开发中的用户反馈收集与分析
我们在开发小程序的过程中根据开发过程中的代码及业务场景,以下是针对需求管理系统的用户反馈收集与分析方案设计: 需求管理系统用户反馈收集与分析方案 一、反馈数据模型设计 // 新增Feedback模型(app/admin/model/Feedback.php) namespace app\admin\model; use think\…...
Flink 通过 Chunjun Oracle LogMiner 实时读取 Oracle 变更日志并写入 Doris 的方案
文章目录 一、 技术背景二、 关键技术1、 Oracle LogMiner2、 Chunjun 的 LogMiner 关键流程3、修复 Chunjun Oracle LogMiner 问题 一、 技术背景 在大数据实时同步场景中,需要将 Oracle 数据库的变更数据(CDC) 采集并写入 Apache Doris&am…...
WordPress系统获取webshell的攻略
一.后台修改模板拿WebShell 1.进入Vulhub靶场并执⾏以下命令开启靶场;在浏览器中访问并安装好 #执⾏命令 cd /vulhub/wordpress/pwnscriptum docker-compose up -d 2. 修改其WP的模板,登陆WP后点击 【外 观】 --》 【编辑】 --》 404.php 3.插入一句话木…...
JMeter基本介绍
Apache JMeter 工具详解 一、JMeter 简介 JMeter 是 Apache 基金会开源的 Java 应用程序,主要用于 性能测试、负载测试 和 功能测试。它通过对服务器或网络资源模拟多种负载条件(如并发用户、持续压力),帮助评估系统性能指标&am…...
npm 安装 pnpm 的详细步骤及注意事项
一、安装步骤 1.全局安装 pnpm npm install -g pnpm2.验证安装 pnpm -v输出版本号即表示安装成功。 二、升级 pnpm 若已安装旧版本,可通过以下命令升级: npm install -g pnpmlatest三、配置镜像加速 设置淘宝镜像 pnpm config set registry http…...
蓝桥杯2023年第十四届省赛真题-子矩阵
题目来自DOTCPP: 暴力思路(两个测试点超时): 题目要求我们求出子矩阵的最大值和最小值的乘积,我们可以枚举矩阵中的所有点,以这个点为其子矩阵的左上顶点,然后判断一下能不能构成子矩阵。如果可…...
如何在 Node.js 中使用 .env 文件管理环境变量 ?
Node.js 应用程序通常依赖于环境变量来管理敏感信息或配置设置。.env 文件已经成为一种流行的本地管理这些变量的方法,而无需在代码存储库中公开它们。本文将探讨 .env 文件为什么重要,以及如何在 Node.js 应用程序中有效的使用它。 为什么使用 .env 文…...
Redis BitMap 用户签到
Redis Bitmap Bitmap(位图)是 Redis 提供的一种用于处理二进制位(bit)的特殊数据结构,它基于 String 类型,每个 bit 代表一个布尔值(0 或 1),可以用于存储大规模的二值状…...
未来办公与生活的新范式——智慧园区
在信息化与智能化技术飞速发展的今天,智慧园区作为一种新兴的城市发展形态,正逐步成为推动产业升级、提升城市管理效率、改善居民生活质量的重要力量。智慧园区不仅融合了先进的信息技术,还深刻体现了可持续发展的理念,为园区内的…...
Hugging Face预训练GPT微调ChatGPT(微调入门!新手友好!)
Hugging Face预训练GPT微调ChatGPT(微调入门!新手友好!) 在实战中,⼤多数情况下都不需要从0开始训练模型,⽽是使⽤“⼤⼚”或者其他研究者开源的已经训练好的⼤模型。 在各种⼤模型开源库中,最…...
【CSS3】化神篇
目录 平面转换平移旋转改变旋转原点多重转换缩放倾斜 渐变线性渐变径向渐变 空间转换平移视距旋转立体呈现缩放 动画使现步骤animation 复合属性animation 属性拆分逐帧动画多组动画 平面转换 作用:为元素添加动态效果,一般与过渡配合使用 概念&#x…...
Unity音频混合器如何暴露参数
音频混合器是Unity推荐管理音效混音的工具,那么如何使用代码对它进行管理呢? 首先我在AudioMixer的Master组中创建了BGM和SFX的分组,你也可以直接用Master没有问题。 这里我以BGM为例,如果要在代码中进行使用就需要将参数暴露出去…...
Vue keepalive学习用法
在Vue中,<keep-alive>的include属性用于指定需要缓存的组件,其实现方式如下: 1. 基本用法 • 字符串形式:通过逗号分隔组件名称,匹配到的组件会被缓存。 <keep-alive include"ComponentA,ComponentB&…...
5-1 使用ECharts将MySQL数据库中的数据可视化
方法一:使用Python Flask框架搭建API 对于技术小白来说,使用ECharts将MySQL数据库中的数据可视化需要分步骤完成。以下是详细的实现流程: 一、技术架构 后端服务:使用Python Flask框架搭建API(简单易学ÿ…...
构建下一代AI Agent:自动化开发与行业落地全解析
1. 下一代AI Agent:概念与核心能力 核心能力描述技术支撑应用价值自主性独立规划与执行任务,无需持续人工干预决策树、强化学习、目标导向规划减少人工干预,提高任务执行效率决策能力评估多种方案并选择最优解决方案贝叶斯决策、多目标优化、…...
如何理解分布式光纤传感器?
关键词:OFDR、分布式光纤传感、光纤传感器 分布式光纤传感器是近年来备受关注的前沿技术,其核心在于将光纤本身作为传感介质和信号传输介质,通过解析光信号在光纤中的散射效应,实现对温度、应变、振动等物理量的连续、无盲区、高…...
四、小白学JAVA-石头剪刀布游戏
1、如何从控制台获取用户输入 import java.util.Scanner;public class Main {public static void main(String[] args) {// 石头剪刀布的思路// 1 2 3 石头 剪刀 布Scanner scanner new Scanner(System.in);System.out.println("请出拳:1.石头 2.剪刀 3.布【…...
【一起来学kubernetes】21、Secret使用详解
Secret 的详细介绍 Secret 是 Kubernetes 中用于存储和管理敏感信息(如密码、令牌、密钥等)的资源对象。Secret的设计目的是为了安全地存储和传输敏感信息,如密码、API密钥、证书等。这些信息通常不应该直接硬编码在配置文件或镜像中&#x…...
css重点知识汇总(一)
css重点知识汇总(一) 引入css的不同方式 link 通过src来获取相应的css资源。除了获取css之外还可以获取其他资源,例如js在页面载入是同步下载可以通过js对dom操作来改变css import css3引入的新方法只能引入css资源需要页面完全载入后才…...
PMP-项目运行环境
你好!我是 Lydia-穎穎 ♥感谢你的陪伴与支持 ~~~ 欢迎一起探索未知的知识和未来,现在lets go go go!!! 1. 影响项目的要素 项目存在在不同的环境下,环境对于项目的交付产生不同的影响。需了解环境对于项目的影响,采取相应措施应对…...
