- c - 在位数组中找到第一个零
- linux - Unix 显示有关匹配两种模式之一的文件的信息
- 正则表达式替换多个文件
- linux - 隐藏来自 xtrace 的命令
我有一个 StreamWriter,它的底层流是一个 FileStream
。以下代码是否保证 FileStream
也将其缓冲区刷新到文件系统上的实际文件中,还是我需要在 上显式调用
?Flush()
文件流
using (var fs = new FileStream("blabla", FileMode.Append)) {
using (var sw = new StreamWriter(fs)) {
sw.WriteLine("Hello, I want to be flushed.");
sw.Flush(); //I need this to also flush onto the file, not just to the FileStream
}
}
根据 MSDN ,“刷新流不会刷新其底层编码器,除非您明确调用 Flush 或 Close”,但我不知道 FileStream 是否可以被视为“底层编码器”。
此外,如果我不指定 FileOptions.WriteThrough,我是否保证操作系统最终会将刷新的行写入磁盘,即使程序在两个流关闭之前崩溃(例如假设没有 使用 {}
block ,只调用 Flush()
)?
在我的场景中,我需要让流保持打开状态(用于日志记录),所以我不能使用 using {}
block ,但我想确保数据始终写入磁盘,即使程序崩溃。如果电源关闭并且操作系统没有刷新到磁盘上,我可以承受丢失数据,但否则我需要操作系统最终刷新,即使我从未在流上正确调用 Close()
.
最佳答案
是的,在StreamWriter
上调用Flush
将导致底层流被Flush
ed。 4.5 版本调用了一个私有(private)的Flush(bool,bool)
函数,其结尾为:
if (flushStream)
{
this.stream.Flush();
}
其中flushStream
是第一个参数,this.stream
是构造StreamWriter
的流,中的调用>Flush()
是 Flush(true,true)
。
(答案的较旧部分 - 我在回答时非常迂回。将答案中最相关的部分移至顶部)
它没有在我能找到的任何地方的文档中明确说明,但是通过将另一个流传递给它而构造的任何流类都应该被假定为“取得该流的所有权”(除非另有特别说明)。
也就是说,一旦您使用 fs
构建了 StreamWriter
,您就不应该自己对 fs
执行任何直接操作。
你从MSDN引用的部分与后面的句子有关:
This allows the encoder to keep its state (partial characters) so that it can encode the next block of characters correctly. This scenario affects UTF8 and UTF7 where certain characters can only be encoded after the encoder receives the adjacent character or characters.
也就是说,您可能已经将数据传递给 Write
,这样您就给了它一些 Unicode 代理项,但不是完整的字符。 Flush
不会将这些代理项写入流。只要您始终将格式良好(完整)的字符串传递给 Write
,您就无需担心这一点。
关于c# - StreamWriter.Flush() 也会调用 FileStream.Flush() 吗?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/13043706/
我需要对同一文件进行一批写入,但在文件内的不同位置。我想以尽可能最好的性能实现这一目标,因此查看了同步 FileStream.Write 和异步 FileStream.BeginWrite 方法。 同
MSDN说FileStream.Flush(True) “还清除所有中间文件缓冲区。”。 “所有中间文件缓冲区”到底是什么意思? 最佳答案 它会将缓冲在文件系统缓存中的文件数据写入磁盘。该数据通常是根
考虑以下摘自 Microsoft docs 的代码: using FileStream createStream = File.Create(fileName); // ...write to str
我对Spark的理解fileStream()方法是将三种类型作为参数:Key , Value , 和 Format .对于文本文件,适当的类型是:LongWritable , Text , 和 Tex
为什么 FileStream.Length 是 long 类型,但 FileStream.Read 参数 - offset 有更短的长度 int 呢? 布莱恩 最佳答案 offset 参数告诉从哪里开
我编写了以下程序,其目的是创建一个给定大小的文件,其中包含一些随机数据。该程序运行良好,并完成了它应该做的事情。但是,我不明白为什么它会消耗 5GB 的 RAM(请参阅我的任务管理器的屏幕截图)。当我
我在一次采访中被问到这个问题,我说答案是 Managed。面试官似乎很惊讶。我的问题是即使它访问一个文件( native /非托管资源),但这个类不是托管的吗?或者你认为我应该有一些后续问题以获得更多
我正在编写一些代码作为打开文件框架的一部分。该文件属于自定义类型,不应由我的应用程序的多个实例打开。为了停止打开多个文件,我使用文件流创建一个锁定文件,然后保持所述文件流打开。 这似乎可以防止我的应用
我正在使用 Apache Commons Net 的 FTPClient 从位于服务器上的文件中读取内容。仅读取一次时效果很好。但是当我尝试读取第二个文件时,FTPClient 的 InputStre
问题 有没有办法在 C# 中创建带偏移量的 FileStream?例如,如果我在偏移量 100 处打开 SomeFile.bin,Stream.Position 将等于 0,但读取和写入将偏移 100
我正在阅读一个简单的文本文件,其中包含使用文件流类的单行。但似乎 filestream.read 在开头添加了一些垃圾字符。 代码下方。 using (var _fs = File.Open(_idF
我正在使用 FileStream 将 FTP 服务器的信息下载到我的 C:\驱动器上的目录中。出于某种原因,即使我什至尝试将目录权限设置为“所有人”访问权限,它也给了我这个异常(exception):
我正在尝试通过将文件作为参数的 API 上传 .srt 文件。 文件存储在服务器上,我正在使用 FileStream 和 StreamWriter 写入: string path = Server.M
我四处搜索了一下,但找不到能完美解决我的问题的东西。我有一些代码,即来 self 的数据库的 FileStream varbinary,并将其制作成客户端计算机上的文件,双击时可以在文件类型的默认应用
我最近在做一个涉及很多FileStreaming 的项目,这是我以前没有真正接触过的。 为了尝试更好地熟悉这些方法的原理,我编写了一些代码(理论上)将文件从一个 dir 下载到另一个,并逐步完成,在我
我通过例如下载文件5 个线程。当其中一个线程完成下载文件部分时 - 它被中止,但所有其余线程都有 ThreadState = WaitSleepJoin 并且显然停止下载。如何解决? while ((
我试图将 5 GB 的 ISO 文件复制到具有 29 GB 可用空间的 32 GB 闪存驱动器上。 Windows 7 拒绝让我拖放文件到闪存驱动器,报告文件对于目标文件系统来说太大了。 我最终了解到
我发现将 BufferedStream 与 FileStream 结合使用没有意义,因为它有自己的缓冲策略。然而,我想知道一件事: FileStream fsWithBuffer = new File
我有一个只读的 FileStream,它是一个方法局部变量: public void SomeMethod() { var fileStream = File.Open(fileName, Fi
我有两个文件流,它们从不同的文件中收集不同的信息: FileStream dataStruc = new FileStream("c:\\temp\\dataStruc.txt", FileMode.
我是一名优秀的程序员,十分优秀!