我写了这个小程序,它从Random.txt读取每第5个字符
在random.txt中,我有一行文字:ABCDEFGHIJKLMnopRST.我得到了预期的结果:
在random.txt中,我有一行文字:ABCDEFGHIJKLMnopRST.我得到了预期的结果:
> A的位置为0
> F的位置是5
> K的位置是10
> P的位置是15
这是代码:
static void Main(string[] args) { StreamReader fp; int n; fp = new StreamReader("d:\\RANDOM.txt"); long prevIoUsBSposition = fp.BaseStream.Position; //In this point BaseStream.Position is 0,as expected n = 0; while (!fp.EndOfStream) { //After !fp.EndOfStream were executed,BaseStream.Position is changed to 19,//so I have to reset it to a prevIoUs position :S fp.BaseStream.Seek(prevIoUsBSposition,SeekOrigin.Begin); Console.WriteLine("Position of " + Convert.tochar(fp.Read()) + " is " + fp.BaseStream.Position); n = n + 5; fp.discardBufferedData(); fp.BaseStream.Seek(n,SeekOrigin.Begin); prevIoUsBSposition = fp.BaseStream.Position; } }
我的问题是,为什么在行之后(!fp.EndOfStream)将BaseStream.Position更改为19,例如BaseStream的结尾.当我调用EndOfStream检查时,我预计,显然是错误的,BaseStream.Position将保持不变?
谢谢.
解决方法
只有某种方法来确定Stream是否在其末端才能实际从中读取内容并检查返回值是否为0.(StreamReader有另一种方法 – 检查其内部缓冲区,但你正确地不让它做通过调用discardBufferedData.)
因此,EndOfStream必须从基本流中读取至少一个字节.而且,由于逐字节读取效率低下,因此读取的内容更多.这就是为什么调用EndOfStream将位置更改为结尾的原因(对于较大的文件,它不会是文件的结尾).
看来你实际上并不需要使用StreamReader,所以你应该直接使用Stream(或者特别是FileStream):
using (Stream fp = new FileStream(@"d:\RANDOM.txt",FileMode.Open)) { int n = 0; while (true) { int read = fp.ReadByte(); if (read == -1) break; char c = (char)read; Console.WriteLine("Position of {0} is {1}.",c,fp.Position); n += 5; fp.Position = n; } }
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。