.NET:关于byte数组在用StreamWriter文件写出后出现多余字符的解决方法及VS方案文件图标显示问题

      这两天在写代码生成工具,然而在生成solution文件(xxx.sln)后,其文件显示图标竟然既不是VS2008的小图标,也不是VS2010小图标;显示的是这样的一个图标;先说明一下我机器装了VS2008和2010;而且双击也没反应。真是挺奇怪的。 而程序目标是生成VS2008那样的方案。

     于是我用VS2008建了一个解决方案,用EditPlus打开与生成的文件比较一下;竟然在生成的方案文件头部多了个未知字符。根据你生成的编码方式不同,多的那个未知字符也不同。好奇心越来越浓。手动删掉多余字符,看一下图标还是没变成正常。为什么呢?难道是文件编码问题,于是在EditPlus另存为时看了一下编码,两文件果然不一样;正确文件的编码是UTF-8 + BOM;而生成的却不是这个编码。另存一下正确编码,图标果然正确显示了;双击也可以打开了。

     1、开始为什么出现编码及多余字符问题呢?

开始代码是这样的:

var xmlSolution =  System.Text.Encoding.Default.GetString(XPNetTool.CodeGenerator.Global.AppResource.XPNet_Solution2008);

写出时是这样的:

StreamWriter sw = new StreamWriter(Filename, false, Encoding.Default);
sw.Write(xmlSolution);
sw.Flush();
sw.Close();

     2、怎样才能避免这种编码问题呢?又怎么解决多余字符呢?

     在byte数组写入到文件时,我们可能要先把byte数组读成string然后再通过StreamWriter对象去操作。我这里的场景是讲一现成的方案模板文件.sln直接拖入资源文件中;然后再生成方案文件时从资源读出的。我通过资源文件点文件时得到的返回值竟是一个byte数组。于是就有byte数组转string的这个过程。这里我的模板方案文件拖入资源文件时编码就是UTF-8 + BOM的,所以读取时就如下了:

var xmlSolution =  System.Text.Encoding.UTF8.GetString(XPNetTool.CodeGenerator.Global.AppResource.XPNet_Solution2008);

写出时如下:

StreamWriter sw = new StreamWriter(Filename, false, new UTF8Encoding(false));//注意这里的 new UTF8Encoding(false) 是去掉多余字符的关键.
sw.Write(xmlSolution);
sw.Flush();
sw.Close();

 

其实说来说去就是编码的问题;所以在文件读取操作时一定注意编码前后一致性。

 

Kevin.Chen

2012-08-15   苏州太仓



 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

奋斗的小壁虎

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值