手机
当前位置:查字典教程网 >编程开发 >C#教程 >c#程序定期把内存信息记录到log日志示例
c#程序定期把内存信息记录到log日志示例
摘要:设立一个定时器tmrMonitor,该定时器会在程序运行时不断把程序的占用内存和占用线程数写到LOGMEM目录下。我设置的定时器间隔是300...

设立一个定时器tmrMonitor,该定时器会在程序运行时不断把程序的占用内存和占用线程数写到LOGMEM目录下。

我设置的定时器间隔是3000毫秒,记录后的信息可以用来分析一段时间内程序的运行状况,比如内存泄漏问题。

复制代码 代码如下:

/// <summary>

/// Timer组件tmrMonitor的Tick事件

/// </summary>

/// <param name="sender"></param>

/// <param name="e"></param>

private void tmrMonitor_Tick(object sender, EventArgs e)

{

string LogAddress = Environment.CurrentDirectory + "Log";

if (!Directory.Exists(LogAddress + "MEM")) //需要System.IO

{

Directory.CreateDirectory(LogAddress + "MEM");

}

LogAddress = String.Concat(LogAddress, "MEM",

DateTime.Now.Year, '-', DateTime.Now.Month, '-',

DateTime.Now.Day, "_mem.log");

//需要 System.Diagnostics;

Process currentProcess = Process.GetCurrentProcess();

StreamWriter sw = new StreamWriter(LogAddress, true);

sw.WriteLine('[' + DateTime.Now.ToString() + ']');

sw.WriteLine("进程标识: " + currentProcess.Id.ToString());

sw.WriteLine("进程名称: " + currentProcess.ProcessName.ToString());

sw.WriteLine("占用内存: " +

(currentProcess.WorkingSet64 / 1024).ToString() + "KB");

sw.WriteLine("线程数量: " + currentProcess.Threads.Count.ToString());

sw.WriteLine();

sw.Close();

}

【c#程序定期把内存信息记录到log日志示例】相关文章:

c#(Socket)同步套接字代码示例

浅谈Java与C#的一些细微差别

使用VS2010 C#开发ActiveX控件(下),完整代码打包下载

c#与WMI使用技巧集第1/2页

C# Dynamic之:ExpandoObject,DynamicObject,DynamicMetaOb的应用(下)

C#获取计算机名,IP,MAC信息实现代码

C# 鼠标穿透窗体功能的实现方法

c#.NET中日志信息写入Windows日志中解决方案

C#:foreach与yield语句的介绍

C#编写的windows计算器的实例代码

精品推荐
分类导航