C# 日志记录工具类:(适用于不想使用log4j等第三方的Log工具的时候,希望自己写个简单类实现)
LogHelper.cs内容如下:
 using System;
using System.Diagnostics;
using System.IO;
using System.Text;
using System.Threading;
using System.Collections.Generic; namespace Tools.Log
{
/// <summary>
/// 多线程安全Log记录工具20180314
/// </summary>
public class LogHelper
{
//为了使用DBGView进行在线调试:
//System.Diagnostics.Debug.WriteLine("Debug模式可见")
//System.Diagnostics.Trace.WriteLine("Debug、Release都可见"); private static Thread WriteThread;
private static readonly Queue<string> MsgQueue; private static readonly string FilePath; private static Boolean autoResetEventFlag = false;
private static AutoResetEvent aEvent = new AutoResetEvent(false);
private static bool flag = true;
public static bool LogFlag = true; static LogHelper()
{
FilePath = AppDomain.CurrentDomain.SetupInformation.ApplicationBase + "App_Log\\";
WriteThread = new Thread(WriteMsg);
MsgQueue = new Queue<string>();
WriteThread.Start();
} public static void LogInfo(string msg)
{
Monitor.Enter(MsgQueue);
MsgQueue.Enqueue(string.Format("{0} {1} {2}", DateTime.Now.ToString("yyyy-MM-dd HH:mm:sss"), "Info", msg));
Monitor.Exit(MsgQueue);
if (autoResetEventFlag) {
aEvent.Set();
}
}
public static void LogError(string msg)
{
Monitor.Enter(MsgQueue);
MsgQueue.Enqueue(string.Format("{0} {1} {2}", DateTime.Now.ToString("yyyy-MM-dd HH:mm:sss"), "Error", msg));
Monitor.Exit(MsgQueue);
if (autoResetEventFlag)
{
aEvent.Set();
}
}
public static void LogWarn(string msg)
{
Monitor.Enter(MsgQueue);
MsgQueue.Enqueue(string.Format("{0} {1} {2}", DateTime.Now.ToString("yyyy-MM-dd HH:mm:sss"), "Warn", msg));
Monitor.Exit(MsgQueue);
if (autoResetEventFlag)
{
aEvent.Set();
}
} /// <summary>
/// ExitThread是退出日志记录线程的方法,一旦退出,无法开启,一般在程序关闭时执行
/// </summary>
public static void ExitThread() {
flag = false;
aEvent.Set();//恢复线程执行
}
private static void WriteMsg()
{
while (flag)
{
//进行记录
if (LogFlag)
{
autoResetEventFlag = false;
if (!Directory.Exists(FilePath))
{
Directory.CreateDirectory(FilePath);
}
string fileName = FilePath + DateTime.Now.ToString("yyyy-MM-dd") + "-Dic.log";
var logStreamWriter = new StreamWriter(fileName, true);
while (MsgQueue.Count > )
{
Monitor.Enter(MsgQueue);
string msg = MsgQueue.Dequeue();
Monitor.Exit(MsgQueue);
logStreamWriter.WriteLine(msg);
if (GetFileSize(fileName) > * )
{
logStreamWriter.Flush();
logStreamWriter.Close();
CopyToBak(fileName);
logStreamWriter = new StreamWriter(fileName, false);
logStreamWriter.Write("");
logStreamWriter.Flush();
logStreamWriter.Close();
logStreamWriter = new StreamWriter(fileName, true);
}
//下面用于DbgView.exe工具进行在线调试
System.Diagnostics.Debug.WriteLine("BS_Debug:"+msg);
System.Diagnostics.Trace.WriteLine("BS_Release:" + msg);
}
logStreamWriter.Flush();
logStreamWriter.Close();
autoResetEventFlag = true;
aEvent.WaitOne();
}
else {
autoResetEventFlag = true;
aEvent.WaitOne();
}
}
}
private static long GetFileSize(string fileName)
{
long strRe = ;
if (File.Exists(fileName))
{
var myFs=new FileInfo(fileName);
strRe = myFs.Length / ;
//Console.WriteLine(strRe);
}
return strRe;
}
private static void CopyToBak(string sFileName)
{
int fileCount = ;
string sBakName = "";
do
{
fileCount++;
sBakName = sFileName + "." + fileCount + ".BAK";
}
while (File.Exists(sBakName));
File.Copy(sFileName, sBakName);
}
}
}

该类由BS风华改编自网上一个类。实现了多线程下面安全记录日志的功能:

使用方法:

    Tools.Log.LogHelper.LogFlag = true; //开启记录
Tools.Log.LogHelper.LogInfo("==========日志记录内容 Info====");
Tools.Log.LogHelper.LogWarn("==========日志记录内容 Warn====");
Tools.Log.LogHelper.LogError("==========日志记录内容 Error====");
Tools.Log.LogHelper.LogFlag = false;//停止记录 Tools.Log.LogHelper.ExitThread();// 退出日志记录线程,一般在程序退出时候调用。

如果有更好的方式,欢迎留言

C# 日志记录工具类--LogHelper.cs测试的更多相关文章

  1. Go/Python/Erlang编程语言对比分析及示例 基于RabbitMQ.Client组件实现RabbitMQ可复用的 ConnectionPool(连接池) 封装一个基于NLog+NLog.Mongo的日志记录工具类LogUtil 分享基于MemoryCache(内存缓存)的缓存工具类,C# B/S 、C/S项目均可以使用!

    Go/Python/Erlang编程语言对比分析及示例   本文主要是介绍Go,从语言对比分析的角度切入.之所以选择与Python.Erlang对比,是因为做为高级语言,它们语言特性上有较大的相似性, ...

  2. 封装一个基于NLog+NLog.Mongo的日志记录工具类LogUtil

    封装一个基于NLog+NLog.Mongo的日志记录工具类LogUtil,代码比较简单,主要是把MongoTarget的配置.FileTarget的配置集成到类中,同时利用缓存依赖来判断是否需要重新创 ...

  3. 封装一个基于NLog+NLog.Mongo的日志记录工具类LogUtil,nloglogutil

    封装一个基于NLog+NLog.Mongo的日志记录工具类LogUtil,代码比较简单,主要是把MongoTarget的配置.FileTarget的配置集成到类中,同时利用缓存依赖来判断是否需要重新创 ...

  4. LogHelper 日志记录帮助类

    1.LogHelper 日志记录帮助类 using System; using System.Collections.Generic; using System.Linq; using System. ...

  5. HttpClientUntils工具类的使用测试及注意事项(包括我改进的工具类和Controller端的注意事项【附 Json 工具类】)

    HttpClient工具类(我改过): package com.taotao.httpclient; import java.io.IOException; import java.net.URI; ...

  6. 基于SQLite日志记录工具--Log4W

    最近压迫自己写点自己的东西,但是水平不高,槽点多,望各位请轻喷,嘿嘿! 以前用过一个Log4Net的东东,但是保存的是文本文件,不好过滤,而且用的不多,也不太熟悉,所以自己也当写一个练练手吧!     ...

  7. AspNetCore.FileLog 一款很不错的日志记录工具

    AspNetCore.FileLog 该项目作者为伟哥,GitHub地址:https://github.com/amh1979:该项目维护者为鸟窝,GitHub地址:https://github.co ...

  8. Java日志记录工具SLF4J介绍

    SLF4J是什么 SLF4J是一个包装类,典型的facade模式的工具,对用户呈现统一的操作方式,兼容各种主流的日志记录框架,典型的有log4j/jdk logging/nop/simple/jaka ...

  9. log4j2和logback动态修改日志级别工具类

    工作中,在排查线上问题时,有以下场景在不重新部署或重启服务的情况下,需要动态调整线上日志级别 1.线上有些日志打印过多干扰有用的日志,需要动态修改线上日志记录器的打印日志级别,调高一些日志级别,打印出 ...

随机推荐

  1. 【c++基础】int转string自动补零

    前言 使用to_string函数可以将不同类型的数据转换为string类,请参考here和here.如果string的位数固定,如何进行自动补零呢?请看本文实例! 代码 确定位数,to_string ...

  2. 【opencv基础】pointPolygonTest

    pointPolygonTest opencv函数 pointPolygonTest: C++: double pointPolygonTest(InputArray contour, Point2f ...

  3. 国内Ubuntu镜像源

    国内有很多Ubuntu的镜像源,包括阿里的.网易的,还有很多教育网的源,比如:清华源.中科大源. 我们这里以中科大的源为例讲解如何修改Ubuntu 18.04里面默认的源. 编辑/etc/apt/so ...

  4. Executor 框架详解

    框架最核心的类是ThreadPoolExecutor,它是Java线程池的实现类,通过Executors工具类,可以创建3种类型的ThreadPoolExecutor: 首先附上ThreadPoolE ...

  5. vue 钩子

    生命周期总结 这么多钩子函数,我们怎么用呢,我想大家可能有这样的疑问吧,我也有,哈哈哈. beforecreate : 举个栗子:可以在这加个loading事件 created :在这结束loadin ...

  6. HDU2034:人见人爱A-B

    Problem Description 参加过上个月月赛的同学一定还记得其中的一个最简单的题目,就是{A}+{B},那个题目求的是两个集合的并集,今天我们这个A-B求的是两个集合的差,就是做集合的减法 ...

  7. [Boolan-C++学习笔记]第一周整理

    1.两种典型类 Complex 无指针 String 有指针 编写思路差异较大 2.使用Class声明:Object Based.类与类之间的关系:Object Oriented 3.头文件的布局 # ...

  8. WPF开源界面库及控件

    WPF开源项目 WPF有很多优秀的开源项目,我以为大家都知道,结果,问了很多人,其实他们不知道.唉,太可惜了! 先介绍两个比较牛逼的界面库 1.MaterialDesignInXamlToolkit ...

  9. aircrack-ng 工具集学习

    一.aircrack-ng简介 aircrack-ng是Aircrack项目的一个分支.是一个与802.11标准的无线网络分析有关的安全软件,主要功能有:网络侦测,数据包嗅探,WEP和WPA/WPA2 ...

  10. 作为一名IT从业者,你在工作和学习中,遇到哪些问题

    版权声明:襄阳雷哥的版权声明 https://blog.csdn.net/FansUnion/article/details/28448975 大家都是IT从业者,遇到的问题多少与类似. 假设能把这些 ...