我们上个例子中的代码:
using System;
using System.Collections.Generic;
using System.Text;
using System.IO;
class Program
{
static void Main(string[]args)
{
try
{
FileStream aFile = new FileStream(@"c:\祝福.txt", FileMode.Open);
StreamReader sr = new StreamReader(aFile);
string strLine = sr.ReadLine();
while(strLine != null)
{
Console.WriteLine(strLine);
strLine = sr.ReadLine();
}
sr.Close();
}
catch (IOException ex)
{
Console.WriteLine(ex.Message);
Console.ReadLine();
return ;
}
Console.ReadKey();
}
}
如果在文件中出现汉字,那么读出来就是乱码。为了解决这个问题,我们用如下代码:
using System;
using System.Collections.Generic;
using System.Text;
using System.IO;
class Program
{
static void Main(string[]args)
{
try
{
string strLine;
FileStream aFile = new FileStream(@"c:\祝福.txt", FileMode.Open);
StreamReader sr = new StreamReader(aFile,System.Text.Encoding.GetEncoding("gb2312"));
//如果有汉字,必需要加入第二个编码参数,要不读出来就是乱码,如果全是英文,可以不加这个参数。
while ((strLine = sr.ReadLine())!= null)
{
Console.WriteLine(strLine);
strLine = sr.ReadLine();
}
sr.Close();
}
catch (IOException ex)
{
Console.WriteLine(ex.Message);
Console.ReadLine();
return ;
}
Console.ReadKey();
}
}
对以上代码我作出以下解释:
StreamReader sr= new StreamReader(aFile, System.Text.Encoding.GetEncoding("gb2312"));
//如果有汉字,必需要填入第二个编码参数,要不读出来就是乱码,如果全是英文,可以不要这个参数。
(strLine = sr.ReadLine())!=null
上式可以分解为如下:
1: strLine=sr.ReadLine();
//sr.ReadLine()就是按行读数据,行之间用“\n”分割;strLine=sr.ReadLine(); 是一个赋值表达式,这个表达式也有一个结果,就是strLine的值。
2: if(strLine!=null) 则条件成立,当ReadLine读到null的时候给了strLine,这时strLine为null,就表示读取完成了。