首页 > 其他 > 详细

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

时间:2016-07-11 14:03:13      阅读:839      评论: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
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!