-
C#编写的简单日志类的示例
本文主要讲解,如何利用C#实现一个日志类,这个类会提供基础的日志写入功能,包括将日志信息写入到一个文本文件中。
这个`SimpleLogger`类提供了三个公共方法:`LogInfo`、`LogWarning`和`LogError`,它们分别用于记录信息、警告和错误级别的日志。每个方法都调用私有的`WriteLog`方法,该方法负责将日志条目格式化为字符串并追加到指定的日志文件中。
要使用这个日志类,你可以像这样创建一个`SimpleLogger`的实例,并调用其方法来记录日志:
在这个示例中,我们创建了一个`SimpleLogger`实例,并指定了日志文件的路径。然后,我们使用`LogInfo`、`LogWarning`和`LogError`方法分别记录了不同级别的日志信息。注意,在记录错误日志时,我们还捕获了一个异常,并将异常信息记录到日志中。
这个简单的日志类仅适用于基本的日志记录需求。对于更复杂的场景,你可能需要考虑使用现有的日志框架,如NLog、log4net或Serilog,它们提供了更丰富的功能和更好的性能。
最后,如果你对vb.net语言还有任何疑问或者需要进一步的帮助,请访问https://www.xin3721.com 本站原创,转载请注明出处:https://www.xin3721.com/ArticlecSharp/c49339.html
using System;
using System.IO;
public class SimpleLogger
{
private readonly string _logFilePath;
public SimpleLogger(string logFilePath)
{
_logFilePath = logFilePath;
// 确保日志文件的目录存在
Directory.CreateDirectory(Path.GetDirectoryName(_logFilePath));
}
public void LogInfo(string message)
{
WriteLog("INFO", message);
}
public void LogWarning(string message)
{
WriteLog("WARNING", message);
}
public void LogError(string message)
{
WriteLog("ERROR", message);
}
private void WriteLog(string level, string message)
{
// 获取当前时间戳
string timestamp = DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss.fff");
// 拼接日志条目
string logEntry = $"{timestamp} [{level}] {message}{Environment.NewLine}";
// 写入日志文件
File.AppendAllText(_logFilePath, logEntry);
}
}
using System.IO;
public class SimpleLogger
{
private readonly string _logFilePath;
public SimpleLogger(string logFilePath)
{
_logFilePath = logFilePath;
// 确保日志文件的目录存在
Directory.CreateDirectory(Path.GetDirectoryName(_logFilePath));
}
public void LogInfo(string message)
{
WriteLog("INFO", message);
}
public void LogWarning(string message)
{
WriteLog("WARNING", message);
}
public void LogError(string message)
{
WriteLog("ERROR", message);
}
private void WriteLog(string level, string message)
{
// 获取当前时间戳
string timestamp = DateTime.Now.ToString("yyyy-MM-dd HH:mm:ss.fff");
// 拼接日志条目
string logEntry = $"{timestamp} [{level}] {message}{Environment.NewLine}";
// 写入日志文件
File.AppendAllText(_logFilePath, logEntry);
}
}
这个`SimpleLogger`类提供了三个公共方法:`LogInfo`、`LogWarning`和`LogError`,它们分别用于记录信息、警告和错误级别的日志。每个方法都调用私有的`WriteLog`方法,该方法负责将日志条目格式化为字符串并追加到指定的日志文件中。
要使用这个日志类,你可以像这样创建一个`SimpleLogger`的实例,并调用其方法来记录日志:
class Program
{
static void Main(string[] args)
{
// 创建一个日志对象,指定日志文件路径
SimpleLogger logger = new SimpleLogger("C:\Logs\app.log");
// 记录一些日志信息
logger.LogInfo("应用程序启动");
logger.LogWarning("某个功能可能存在问题");
try
{
// 假设这里有一些可能抛出异常的代码
throw new InvalidOperationException("操作无效");
}
catch (Exception ex)
{
logger.LogError($"发生错误: {ex.Message}");
}
Console.WriteLine("日志已写入文件");
Console.ReadLine();
}
}
{
static void Main(string[] args)
{
// 创建一个日志对象,指定日志文件路径
SimpleLogger logger = new SimpleLogger("C:\Logs\app.log");
// 记录一些日志信息
logger.LogInfo("应用程序启动");
logger.LogWarning("某个功能可能存在问题");
try
{
// 假设这里有一些可能抛出异常的代码
throw new InvalidOperationException("操作无效");
}
catch (Exception ex)
{
logger.LogError($"发生错误: {ex.Message}");
}
Console.WriteLine("日志已写入文件");
Console.ReadLine();
}
}
在这个示例中,我们创建了一个`SimpleLogger`实例,并指定了日志文件的路径。然后,我们使用`LogInfo`、`LogWarning`和`LogError`方法分别记录了不同级别的日志信息。注意,在记录错误日志时,我们还捕获了一个异常,并将异常信息记录到日志中。
这个简单的日志类仅适用于基本的日志记录需求。对于更复杂的场景,你可能需要考虑使用现有的日志框架,如NLog、log4net或Serilog,它们提供了更丰富的功能和更好的性能。
最后,如果你对vb.net语言还有任何疑问或者需要进一步的帮助,请访问https://www.xin3721.com 本站原创,转载请注明出处:https://www.xin3721.com/ArticlecSharp/c49339.html
栏目列表
最新更新
使用Java实现KMZ和KML数据的直接解析
Spring Boot最经典的20道面试题你都会了吗
Java中Instant的使用及转换
Spring中ClassPath指的是哪些地方
在SpringBoot项目中使用JetCache缓存的详细教
SpringBoot使用@Scheduled实现定时任务的并行
使用Spring事件监听机制实现跨模块调用的
详解SpringBoot如何让指定的Bean先加载
Spring实现资源的动态加载和卸载的方法小
使用Python发送电子邮件
SQL SERVER中递归
2个场景实例讲解GaussDB(DWS)基表统计信息估
常用的 SQL Server 关键字及其含义
动手分析SQL Server中的事务中使用的锁
openGauss内核分析:SQL by pass & 经典执行
一招教你如何高效批量导入与更新数据
天天写SQL,这些神奇的特性你知道吗?
openGauss内核分析:执行计划生成
[IM002]Navicat ODBC驱动器管理器 未发现数据
初入Sql Server 之 存储过程的简单使用
uniapp/H5 获取手机桌面壁纸 (静态壁纸)
[前端] DNS解析与优化
为什么在js中需要添加addEventListener()?
JS模块化系统
js通过Object.defineProperty() 定义和控制对象
这是目前我见过最好的跨域解决方案!
减少回流与重绘
减少回流与重绘
如何使用KrpanoToolJS在浏览器切图
performance.now() 与 Date.now() 对比