C# 操作线程的通用类[测试通过]
2010-12-20 17:50
399 查看
进程管理就是对服务器性能的管理和协调,在程序的运行角度来看非常重要,也可以根据操作进程的手段,衍生很多实用和智能的功能,以下就是介绍一个自己写的进程通用操作类,功能如下:
1.把ProcessUtility类直接复制到程序中即可实用。
2.调用方法 ex:ProcessUtility.resetProcessByPName("explorer");
代码如下:
using System;
using System.Collections.Generic;
using System.Diagnostics;
using System.Linq;
using System.Text;
/// <summary>
/// author:Stone_W
/// date:2010.12.20
/// desc:进程管理类
/// </summary>
public class ProcessUtility
{
#region 进程的cpu使用率
/// <summary>
/// 进程的cpu使用率
/// </summary>
/// <param name="processName">进程的名称</param>
/// <returns>string</returns>
public static string GetProcessRate(string processName)
{
string result = String.Empty;
try
{
PerformanceCounter pfc = new PerformanceCounter(); // 性能计数器
pfc.CategoryName = "Process"; // 指定获取计算机进程信息
pfc.CounterName = "% Processor Time"; // 占有率
pfc.InstanceName = processName; // 指定进程
pfc.MachineName = ".";
result = Math.Round(pfc.NextValue(), 2) + "%";
}
catch (Exception ex) { }
return result;
}
#endregion
#region 进程内存使用(单位:K)
/// <summary>
/// 进程内存使用(单位:K)
/// </summary>
/// <param name="pcs">进程实体</param>
/// <returns>string</returns>
public static string GetProcessDDR(Process pcs)
{
string result = String.Empty;
try
{
result = (pcs.PrivateMemorySize / 1000.0).ToString();
}
catch (Exception ex) { }
return result;
}
#endregion
#region 关闭进程
/// <summary>
/// 关闭进程
/// </summary>
/// <param name="pName">进程的名称</param>
/// <returns>bool</returns>
public static bool StopProcessByPName(string pName)
{
bool result = false;
if (!String.IsNullOrEmpty(pName))
{
try
{
Process[] myProcesses = Process.GetProcesses();
foreach (System.Diagnostics.Process myProcess in myProcesses)
{
if (myProcess.ProcessName.ToUpper() == pName.ToUpper().Trim())
{
myProcess.Kill();
}
}
result = true;
}
catch (Exception ex) { }
}
return result;
}
#endregion
#region 重新启动进程
/// <summary>
/// 重新启动进程
/// </summary>
/// <param name="pName">进程名称</param>
/// <returns>bool</returns>
public static bool resetProcessByPName(string pName)
{
bool result = false;
if (!String.IsNullOrEmpty(pName))
{
try
{
Process[] myProcesses;
myProcesses = Process.GetProcessesByName(pName);
foreach (Process myProcess in myProcesses)
{
myProcess.Kill();
}
result = true;
}
catch (Exception ex) { }
}
return result;
}
#endregion
}
1.把ProcessUtility类直接复制到程序中即可实用。
2.调用方法 ex:ProcessUtility.resetProcessByPName("explorer");
代码如下:
using System;
using System.Collections.Generic;
using System.Diagnostics;
using System.Linq;
using System.Text;
/// <summary>
/// author:Stone_W
/// date:2010.12.20
/// desc:进程管理类
/// </summary>
public class ProcessUtility
{
#region 进程的cpu使用率
/// <summary>
/// 进程的cpu使用率
/// </summary>
/// <param name="processName">进程的名称</param>
/// <returns>string</returns>
public static string GetProcessRate(string processName)
{
string result = String.Empty;
try
{
PerformanceCounter pfc = new PerformanceCounter(); // 性能计数器
pfc.CategoryName = "Process"; // 指定获取计算机进程信息
pfc.CounterName = "% Processor Time"; // 占有率
pfc.InstanceName = processName; // 指定进程
pfc.MachineName = ".";
result = Math.Round(pfc.NextValue(), 2) + "%";
}
catch (Exception ex) { }
return result;
}
#endregion
#region 进程内存使用(单位:K)
/// <summary>
/// 进程内存使用(单位:K)
/// </summary>
/// <param name="pcs">进程实体</param>
/// <returns>string</returns>
public static string GetProcessDDR(Process pcs)
{
string result = String.Empty;
try
{
result = (pcs.PrivateMemorySize / 1000.0).ToString();
}
catch (Exception ex) { }
return result;
}
#endregion
#region 关闭进程
/// <summary>
/// 关闭进程
/// </summary>
/// <param name="pName">进程的名称</param>
/// <returns>bool</returns>
public static bool StopProcessByPName(string pName)
{
bool result = false;
if (!String.IsNullOrEmpty(pName))
{
try
{
Process[] myProcesses = Process.GetProcesses();
foreach (System.Diagnostics.Process myProcess in myProcesses)
{
if (myProcess.ProcessName.ToUpper() == pName.ToUpper().Trim())
{
myProcess.Kill();
}
}
result = true;
}
catch (Exception ex) { }
}
return result;
}
#endregion
#region 重新启动进程
/// <summary>
/// 重新启动进程
/// </summary>
/// <param name="pName">进程名称</param>
/// <returns>bool</returns>
public static bool resetProcessByPName(string pName)
{
bool result = false;
if (!String.IsNullOrEmpty(pName))
{
try
{
Process[] myProcesses;
myProcesses = Process.GetProcessesByName(pName);
foreach (Process myProcess in myProcesses)
{
myProcess.Kill();
}
result = true;
}
catch (Exception ex) { }
}
return result;
}
#endregion
}
相关文章推荐
- C# 操作线程的通用类[测试通过]
- C#跨线程操作控件 通过委托处理,MSDN上又很详细用法的说明
- !!c# 委托与多线程 -- 相比background来说,本方法针对当需要通过异步代理发起UI操作,而后线程中进行sleep操作的时使用
- C# 通过线程来控制进度条(转)--讲解多线程对界面的操作
- c#操作进程、服务、注册表(源码测试通过)
- 线程间操作无效: 从不是创建控件“label1”的线程访问它。C#定时器
- C#连接Oracle数据库通过存储过程操作数据库
- C# 线程知识--使用Task执行异步操作(转)
- C# 采用系统委托的方式处理线程内操作窗体控件
- 一个自己测试通过的发邮件操作
- C#中利用委托实现多线程跨线程操作
- C#中的线程操作
- C# 线程间操作无效: 从不是创建控件“receivemsg”的线程访问它。
- C#通过引用Office Excel (2007) 组件实现对Excel文件的操作
- C# 怎么通过Iphlpapi.dll 这个API操作路由表
- C# 线程知识--使用Task执行异步操作
- C#线程间操作无效的处理(各处收集贴)
- C# - 线程操作
- C#中通过引用来传递参数?有几种?区别?例?(传入参数A,并返回操作后的A)?
- C#通过COM组件操作IE浏览器(二):使用IHTMLDocument3完成登录