码迷,mamicode.com
首页 > 其他好文 > 详细

The output char buffer is too small to contain the decoded characters, encoding 'Unicode (UTF-8)' fallback 'System.Text.DecoderReplacementFallback'.

时间:2016-07-11 14:05:46      阅读:224      评论:0      收藏:0      [点我收藏+]

标签:

Exception when executing

if (br.PeekChar() != -1)

br is a binary reader.

The data to peak is D000 (D0=208)

 

The cause is, for PeekChar, after peak, the value will be transformed to char.

But Unicode and normal char has different length.

 

If I use br.ReadByte(), there will be no problem.

But if it hit the end of one file, br.ReadByte() would threw an error.

 

I googled and found many similar errors.

The best article that solved my problem is

https://social.msdn.microsoft.com/Forums/vstudio/en-US/7bd62472-b4ff-47c7-9bbd-7af9512d0301/binaryreaderpeekchar-fails-when-checking-for-end-of-file?forum=clr

 

Use the following to identify a file end and don‘t use PeekChar().

if(reader.BaseStream.Position == reader.BaseStream.Length)

 

or exclaim the Encoding format. Then PeekChar will be OK to use.

BinaryReader binaryReader = new BinaryReader(memoryStream, Encoding.ASCII);

 

I used the second one. problem solved.

 

The output char buffer is too small to contain the decoded characters, encoding 'Unicode (UTF-8)' fallback 'System.Text.DecoderReplacementFallback'.

标签:

原文地址:http://www.cnblogs.com/jiceberg420/p/5659827.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!