【转】!C#中的Stream相关

计算机文件基本上分为二种:二进制文件和 ASCII(也称纯文本文件)。图形文件及文字处理程序等计算机程序都属于二进制文件。这些文件含有特殊的格式及计算机代码。ASCII 则是可以用任何文字处理程序阅读的简单文本文件,由一些字符的串行组成,具有一定的编码规则。如果你将文本文件通过修改后缀的方式修改成图片,但对于程序来说本质上还是文本文件。

FileStream类——这个类主要用于在二进制文件中读写二进制数据——也可以使用它读写任何文件。 流是传输数据的对象,介于程序中直接与流交互,可以将流理解为数据本身。一个FileStream的实例可以理解为一个具体的文件。

System.IO.MemoryStream类和System.Net.Sockets.NetworkStream类。

继承关系如下图(除NetWorkStream CryptoStream外,其他均在System.IO下):

流,都是写一点多一点。从流中读一点,流就少一点,可以通过方法返回的数据来判断流读到哪了。

在使用完流后记得释放流

  • Dispose(true),关闭基础流,释放 System.IO.StreamReader 使用的非托管资源和托管资源。
  • Dispose(false),关闭基础流,仅释放非托管资源。
  • Close(),关闭 System.IO.StreamReader 对象和基础流,并释放与读取器关联的所有系统资源。允许其他应用程序为同一个文件设置流。这个操作也会刷新缓冲区。
  • 当一个类里面既有Close又有Dispose时,基本这两个函数干的事情是差不多的。

https://referencesource.microsoft.com/#mscorlib/system/io/stream.cs源码

C# 托管资源与非托管资源 - 改变从今天开始 - 博客园​www.cnblogs.com

  • 托管代码:为.NET编写的代码,交由CLR管理(其中包含了GC服务)
  • 非托管代码:不在CLR控制下运行的代码。比如Win32 C/C++ DLL

FileStream使用举例

FileStream读取

FileStream写入


StreamReader(流读取器)StreamWriter(流写入器)——这两个类可以对文本文件应用程序进行读写;文本文件有不同的编码格式,StreamReader会帮我们自动处理,你也可以指定编码格式去读写流。除此之外,还能对应用程序进行标准的输入输出,常见于对Process输入输出;可以将这读取器或写入器理解为单向的管道,给予我们读写的能力。这两种管道也是专门处理流的。而管道是建立在流的基础之上的。可以通过参数:路径字符串,已有文件流构件管道,还可以通过FileInfo的实例的CreateText()方法来构建管道。

与流相同的是:管道也要CloseDispose,只有Dispose(false)是只关管道,不关流。

StreamReader源码

StreamReader示例

StreamWriter示例

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/436886.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

【转】!!c#文件系统操作类继承关系图

自己总结的,给大家参考一下,

php elasticsearch 获取索引所有文档_Elasticsearch客户端主要方法的使用规则

安装1.在 composer.json 文件中引入 elasticsearch-php:{ "require": { "elasticsearch/elasticsearch": "~6.0" }}2.用 composer 安装客户端:curl -s http://getcomposer.org/installer | phpphp composer.…

【转】SVN trunk(主线) branch(分支) tag(标记) 用法详解和详细操作步骤

转自:https://monday.blog.csdn.net/article/details/51122637 一:使用场景: 假如你的项目(这里指的是手机客户端项目)的某个版本(例如1.0版本)已经完成开发、测试并已经上线了,接…

【转】人工智能教程-前言

前言 大家好!欢迎来到我的网站! 人工智能被认为是一种拯救世界、终结世界的技术。毋庸置疑,人工智能时代就要来临了,科幻电影中的场景将成为现实,未来已来! 我很庆幸。十四年前就认定了人工智能专业&…

【转】人工智能-1.1.1 什么是神经网络

1.1.1 什么是神经网络 什么是人工智能?通俗来讲,就是让机器能像人一样思考。这个无需解释太多,因为通过各种科幻电影我们已经对人工智能很熟悉了。大家现在感兴趣的应该是——如何实现人工智能? 从1956年夏季首次提出“人工智能…

【转】人工智能-1.2.2 神经网络是如何进行预测的

上一篇文章中我们已经知道了如何将数据输入到神经网络中。那么神经网络是如何根据这些数据进行预测的呢?我们将一张图片输入到神经网络中,神经网络是如何预测这张图中是否有猫的呢?? 这个预测的过程其实只是基于一个简单的公式&a…

js 根据公历日期 算出农历_一招教会你公历换算成农历,要不要试试看

古代的历法是干支纪年,俗称农历或阴历,现在我们都统一采用公历的阿拉伯数字纪年。因此,就存在着一个历法的换算问题。当然,我们可以查历书就直接知道了,但是这个方法并不一定方便。现在告诉大家一个简单的口诀&#xf…

【转】Power Platform(简介)

Power Platform 系统通过允许用户执行以下三个关键操作来帮助他们推动业务发展:使用 Power BI 从数据中获得见解,通过使用 PowerApps 构建的应用程序来推动智能业务流程,以及使用 Power Automate 自动执行这些流程。 这些解决方案彼此配合协作…

【转】人工智能-1.2.1 如何将数据输入到神经网络中

1.2.1 如何将数据输入到神经网络中 通过对前面文章的学习,我们已经知道神经网络可以实现真正的人工智能。本小节我会进行详细地讲解,让大家彻底地弄懂神经网络。在仅仅只学完一篇文章后,你肯定依然感觉朦胧,这是正常的&#xff0…

Qt实现多屏幕多分辨率自适应

这里仅大概描述一下实现思路。 运行条件 两个屏幕,分辨率不同。Qt软件 问题提出 前段时间写了一个软件,窗口内有自绘内容。 自绘内容里面用的长度单位都是像素。可想而知,在开发者的电脑屏幕上大小都是符合要求的。到这一步都没问题。 软…

您需要来自pc的权限才能_微信电脑版还是鸡肋吗?微信PC版3.0内测体验

[PConline 应用]微信PC版3.0来了!这到底是个怎样的版本?先说结果吧,好消息是微信PC端新版很快就要上线了,坏消息是这一回采用是邀请内测制,注定了很多人只能等到正式上线后,才能见到新版本!目前…

【转】【MySQL】事务与锁(四):行锁到底锁住的是什么?记录?字段?索引?

首先我们有三张表t1,t2,t3,它们都是只有两个字段, int类型的id和varchar类型的name;区别是t1没有索引,t2有主键索引,t3有唯一索引。 再强调一次,在实验前必须提前关闭自动提交,set autocommitof…

【编译原理】理解BNF

BNF范式 下面来自百度百科: 巴科斯范式(BNF)所描述的语法是与上下文无关的。它具有语法简单,表示明确,便于语法分析和编译的特点。 源码解析使用的算法就是BNF或者其改进算法。 什么是上下文无关文法呢? …

【GUI开发】图像处理类软件的浏览功能实现模型

图像处理软件包括但不限于: 图片浏览器,2D地图浏览器、图片编辑器等软件。 为了处理大分辨率图片,一般采用GDAL加载图像,GDAL可以动态加载图像的一部分,可以建立图像金字塔,优化加载速度。 一般的图像处理…

自动事务_JDBC进阶(二)事务编程

一、事务简介事务是用户定义的一个数据库操作序列,这些操作要么全做,要么全不做,是一个不可分割的工作单位。事务具有ACID特性:原子性(Atomicity) —— 原子性是指事务是一个不可分割的工作单位&#xff0c…

【精华】详解Qt中的内存管理机制

前言 内存管理,是对软件中内存资源的分配与释放进行有效管理的方法和理论。 众所周知,内存管理是软件开发的一个重要的内容。软件规模越大,内存管理可能出现的问题越多。如果像C语言一样手动地管理内存,一会给开发人员带来巨大的…

【转】2.1【MySQL】运行原理(一):查询sql的执行过程及MySQL架构分析

MySQL的发展历史和版本分支: 时间里程碑1996 年MySQL1.0 发布。它的历史可以追溯到 1979 年,作者 Monty 用 BASIC 设计的一个报表工具。1996 年 10 月3.11.1 发布。MySQL 没有 2.x 版本。2000 年ISAM 升级成 MyISAM 引擎。MySQL 开源。2003 年MySQL4.0 …

【转】2.2【MySQL】运行原理(二):InnoDB 内存结构、磁盘结构及update sql执行过程分析

前一篇讲完了查询流程,我们是不是再讲讲更新流程、插入流程和删除流程?在数据库里面,我们说的update操作其实包括了更新、插入和删除。如果大家有看过MyBatis的源码,应该知道Executor里面也只有doQuery()和doUpdate()的方法&#…

【转】2.3【MySQL】运行原理(三)InnoDB 逻辑存储结构

MySQL的存储结构分为5级:表空间、段、簇、页、行。 1.表空间 TableSpace 上篇【MySQL】从InnoDB的内存结构、磁盘结构到update sql执行过程分析 在磁盘结构部分就说过了,表空间可以看做是InnoDB 存储引擎逻辑结构的最高层,所有的数据都存放在…