流无处不在,只要是关于到文件的输入、输出、更新等,关于IO流,项目中还是经常用到的,写log日志免不了要与其打交道,现在需要用到,就顺道好好回顾一下进行整理,首先是几个需要用到的类的说明,其实说简单点,就是对文件夹、文件、文件内容进行编辑。

1. 创建文件、文件夹

        public void OperationFile()
{
//创建文件
if (!File.Exists("Log.txt"))
{
File.Create("Log.txt"); } //创建文件夹
if (!Directory.Exists("Log"))
{
Directory.CreateDirectory("Log");
}
}

2. 读写数据到文件中

FileStream 原始,比较复杂,处理的数据多

读取文件数据

        public void ReadFileStream()
{
//打开数据
//FileStream fs = File.OpenRead("201704191450.txt");
//FileInfo fileinfo = new FileInfo("201704191450.txt");
//FileStream fs = fileinfo.OpenRead(); //读取数据
byte[] bytedata = new byte[];
char[] chardata = new char[];
FileStream ffs = new FileStream("TestRead.txt",FileMode.Open);
//执行文件指针位置
ffs.Seek(,SeekOrigin.Begin);
//读取数据,其起始位置为seek指定的指针位置末
ffs.Read(bytedata,,);
//设置转码格式
Decoder d = Encoding.UTF8.GetDecoder();
d.GetChars(bytedata,,bytedata.Length,chardata,);
Console.WriteLine(chardata);
Console.ReadKey(); }

写入文件数据

        public void WriteFileStream()
{
//写入数据
byte[] byteData = new byte[];
char[] charData = new char[];
FileStream fis = new FileStream("TestWrite.txt", FileMode.Create);
charData = ("This is a jokey").ToArray();
byteData = new byte[charData.Length];
Encoder e = Encoding.UTF8.GetEncoder();
e.GetBytes(charData, , charData.Length, byteData, , true);
fis.Seek(, SeekOrigin.Begin);
fis.Write(byteData, , byteData.Length);
}

由此可见,操作字符数据比较麻烦。而StreamWritrer、StreamReader不需要设置指针位置,读写文件时,比较灵活

StreamReader读取文件数据

        /// <summary>
/// StreamReader读取日志
/// </summary>
public void ReadLog()
{
StreamReader sr = new StreamReader("201704191451.txt", true);
string line = sr.ReadLine();
while (line!=null)
{
Console.WriteLine(line);
line = sr.ReadLine();
} sr.Close();
}

StreamWriter写入文件数据

        /// <summary>
/// StreamWrite写入日志
/// </summary>
/// <param name="ex"></param>
public void WriteExLog(string ex)
{
StreamWriter sw = new StreamWriter(DateTime.Now.ToString("yyyyMMddHHmm")+".txt",true);
sw.WriteLine(DateTime.Now.ToString("G")+" "+ex);
sw.Close(); }

两者一进行对比,可见StreamWriter、StreamReader确实比FileStream方便很多

关于流文件的使用,上面仅仅是单一的操作,实际项目中,多为混合模式,各种判断柔和在一起,这里也不多说什么,先写一个相对来书综合点的方法

       public void OperationStream()
{
//当前Debug下+创建文件夹
string straddrsfile = AppDomain.CurrentDomain.BaseDirectory + Path.DirectorySeparatorChar.ToString() + "Test1";
//当前路径+文件名
string straddrspath = straddrsfile + Path.DirectorySeparatorChar.ToString() + "Test1" + DateTime.Now.ToString("yyyyMMddHHmmss") + ".xml";
straddrspath = straddrspath.Replace("\\", "/");
if (!File.Exists(straddrsfile))
{
//创建文件夹
Directory.CreateDirectory(straddrsfile);
//创建文件
StreamWriter sw = new StreamWriter(straddrspath,true);
//写入数据
sw.WriteLine(DateTime.Now.ToString("G") + "This is a jokey");
sw.Close();
//读取数据
StreamReader sr = new StreamReader(straddrspath,true);
string line = sr.ReadLine();
//输出数据
while (line != null)
{
Console.WriteLine(line);
line = sr.ReadLine();
}
sr.Close();
Console.ReadKey();
}
}

对于这些流关联的类,其重载的方法有很多,向那些参数的说明,指尖敲击下键盘,点下联想看看说明,就出来,总之,深入的研究清一个问题需要大量的时间,结果还未可知,当前项目既然需要这个日志,就稍稍巩固下。

------分割线---------------

实战:现在接手的项目中需要异常日志,初步思路如下:

        //記錄異常日誌  Log file txt
public void WriteTxtLog(Exception ex,string sysCode,string functId)
{
//文件夾名稱
string logFolder = ConfigurationManager.AppSettings["LogFolder"];
//文件名
string logFolderName = ConfigurationManager.AppSettings["LogFolderName"];
//文件夾路徑
string logFolderPath = ConfigurationManager.AppSettings["LogFolderPath"];
//文件路徑
string path = logFolderPath + "\\" + logFolder + "\\" + DateTime.Now.ToString("yyyyMMdd") + logFolderName;
//创建文件夹
if (!Directory.Exists(logFolderPath+"\\"+ logFolder))
{
Directory.CreateDirectory(logFolderPath + "\\" + logFolder);
}
//不存存在txt,則創建,存在則追加
var sw = !File.Exists(path) == true ? new StreamWriter(path, true) : File.AppendText(path);
//写入数据
sw.WriteLine("..................");
sw.WriteLine("異常日誌,開始時間:" + DateTime.Now.ToString("yyyyMMdd HH:mm:ss"));
sw.WriteLine("系統名:" + sysCode + " 功能代號:" + functId + " 異常錯誤信息:" + ex.ToString());
sw.WriteLine("異常日誌,完成時間:" + DateTime.Now.ToString("yyyyMMdd HH:mm:ss"));
sw.WriteLine("..................");
sw.Close();
}

市人皆大笑,举手揶揄之

IO流中的Stream相关对象的更多相关文章

  1. 第54节:Java当中的IO流(中)

    Java当中的IO流(中) 删除目录 // 简书作者:达叔小生 import java.io.File; public class Demo{ public static void main(Stri ...

  2. Java当中的IO流(中)

    Java当中的IO流(中) 删除目录 import java.io.File; public class Demo{ public static void main(String[] args){ / ...

  3. 规范之“用流中的Stream.Of(arr1,arr2)将两个集合合并”

    案例:用流中的Stream.Of(arr1,arr2)将两个集合合并 /** * 功能描述: * 两个对象集合添加到一起 * 在用flatMap扁平化改为Stream<User> * 这样 ...

  4. 揭开Java IO流中的flush()的神秘面纱

    大家在使用Java IO流中OutputStream.PrintWriter --时,会经常用到它的flush()方法. 与在网络硬件中缓存一样,流还可以在软件中得到缓存,即直接在Java代码中缓存. ...

  5. io流中的装饰模式对理解io流的重要性

    为了说明 io流中的装饰者模式对理解io流的重要性,我想先简要介绍以下io的装饰模式. 装饰(decorator)你也可以翻译成修饰.比如:一个会精通化学数学的物理学家.在这个"物理学家&q ...

  6. Java中IO流中所涉及到的各类方法介绍

    IO流之字节流 (1)IO用于在设备间进行数据传输的操作 (2)分类: A:流向 输入流 读取数据 输出流 写出数据 B:数据类型 字节流 字节输入流 字节输出流 字符流 字符输入流 字符输出流 注意 ...

  7. IO流中的字符输入输出流及try...catch处理流处理中的异常

    使用字节流读取中文的问题 import java.io.FileInputStream; import java.io.IOException; /* 使用字节流读取中文文件 1个中文 GBK:占用两 ...

  8. 关于Java中面向对象章节、IO 流中的重点基础知识。

    一.面向对象的三大特征,以及作用. 答:面向对象的三大特征即,封装性.继承性.多态性. 其分别的作用为 : 封装作用:将数据封装起来,提高数据的安全性, 继承作用:提高代码的复用性,减少冗余代码. 多 ...

  9. Java中IO流中的装饰设计模式(BufferReader的原理)

    本文粗略的介绍下JavaIO的整体框架,重在解释BufferReader/BufferWriter的演变过程和原理(对应的设计模式) 一.JavaIO的简介 流按操作数据分为两种:字节流与字符流. 流 ...

随机推荐

  1. iOS基础之顺传逆传传值(delegate、block)

    写给iOS新手的福利! 在项目中经常会用到传值,根据传值的方向分为顺传(从根控制器到子控制器)和逆传(从子控制器到根控制器).在这里写了个Demo简单演示了效果,创建了两个控制器: 一个为根控制器,一 ...

  2. RabbitMQ(从安装到使用)

    RabbitMQ 一,RabbitMQ简单介绍: RabbitMQ是一个在AMQP基础上完整的,可复用的企业消息系统.他遵循Mozilla Public License开源协议. MQ全称为Messa ...

  3. 定制Maven的ArcheType

    根据需要定制Maven的ArcheType的好处不言而喻了,我就不再啰嗦.定制一般通过从Maven的项目构建,比手动构建省去了配置文件的编写.资源文件的复制等繁琐的操作,下面我们就说下从Maven项目 ...

  4. Java并发之线程异常捕获

    由于线程的本质特性,使得你不能捕获从线程中逃逸的异常,如: import java.util.concurrent.ExecutorService; import java.util.concurre ...

  5. 2017,科学使用strace神器(附代码,举栗子)

    我感到惊讶,都2017年了,几乎没有人知道他们可以使用strace的了解所有事情.它总是我拔出的第一个调试工具之一,因为它通常在我运行的Linux系统上可用,并且它可以用于解决各种各样的问题. 什么是 ...

  6. WebApi接口请求失败,找不到资源。

    WebApi开发接口,实现同步数据库的数据给安卓. public class UserInfoController : ApiControllerBase { private UserBLL user ...

  7. Hibernate学习笔记①

    ---恢复内容开始--- 1.JavaEE的三层结构 WEB层--Service层--DAO层 2.Hibernate版本 Hibernate3.x  4.x  5.x 4版本是过渡版本 不使用  5 ...

  8. 基于 Koa平台Node.js开发的KoaHub.js的输出json到页面代码

    koahub-body-res koahub body res Format koa's respond json. Installation $ npm install koahub-body-re ...

  9. 1067: [SCOI2007]降雨量

    1067: [SCOI2007]降雨量 Time Limit: 1 Sec  Memory Limit: 162 MBSubmit: 2148  Solved: 554[Submit][Status] ...

  10. app 评分

    p.p1 { margin: 0.0px 0.0px 0.0px 0.0px; font: 18.0px Menlo; color: #822e0e } p.p2 { margin: 0.0px 0. ...