不要使用PeekChar()判断EOF_.net framework编程

发布时间:2020-07-22 10:13:39 作者:veryzhou
来源:网络 阅读:278

这两天使用.net framework编程,其中有个任务是将一个二进制文件格式转换成mpeg4码流的媒体文件。其中需要使用System.IO.BinaryReader类,按照MSDN和我自己使用的SDK的范例,我使用了类似下面的代码。

using(FileStream inputFile = new FileStream("name.bin",FileMode.Open))
using(BinaryReader br = new BinaryReader(inputFile))
{
while(br.PeekChar() != -1) ///<----崩溃
{
////......
}
}

以上代码总是会在调用个PeekChar()的时候发生崩溃,错误信息为:输出字符缓冲区太小,无法包含解码后的字符,编码“Unicode (UTF-8)”的操作回退“System.Text.DecoderReplacementFallback”。 搞不清楚怎么回事,后来上网反复查,发现这个竟然是一个.net framework的bug。

其中涉及到UTF编码格式的一些知识,我也不太明白,不过有一点是可以确定,官方推荐不要使用PeekChar()来判断EOF。这真是让我很晕啊,怎么那么多官方文档和SDK里面都用错误的例子啊,被误导了,耽误了不少时间呢。

推荐使用的判断EOF的方法是:

br.BaseStream.Position < br.BaseStream.Length

参考文献:

http://forums.microsoft.com/MSDN/ShowPost.aspx?PostID=1939995&SiteID=1

http://www.codeplex.com/SvnBridge/WorkItem/View.aspx?WorkItemId=9077

推荐阅读:
  1. IDEA使用Mybatis插件 MyBatisCodeHelper-Pro
  2. mybatis的好帮手之MybatisCodeHelperPro详解

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

peekchar() eof fram

上一篇:使用linux的tmpwatch命令删除暂存文件

下一篇:有哪些常见的Java注解

相关阅读

您好,登录后才能下订单哦!

密码登录
登录注册
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》