详解C#获取特定进程CPU和内存使用率

首先是获取特定进程对象,可以使用Process.GetProcesses()方法来获取系统中运行的所有进程,或者使用Process.GetCurrentProcess()方法来获取当前程序所对应的进程对象。当有了进程对象后,可以通过进程对象名称来创建PerformanceCounter类型对象,通过设定PerformanceCounter构造函数的参数实现获取特定进程的CPU和内存使用情况。

具体实例代码如下:

首先是获取本机中所有进程对象,分别输出某一时刻各个进程的内存使用情况:

using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Diagnostics;
using System.Threading;

namespace CSharpPerformance
{//该程序可以实时监控所有进程或者指定进程的工作集、私有工作集
  class Program
  {
    static void Main(string[] args)
    {
      //新建一个Stopwatch变量用来统计程序运行时间
      Stopwatch watch = Stopwatch.StartNew();
      //获取本机运行的所有进程ID和进程名,并输出哥进程所使用的工作集和私有工作集
      foreach (Process ps in Process.GetProcesses())
      {
        PerformanceCounter pf1 = new PerformanceCounter("Process", "Working Set - Private", ps.ProcessName);
        PerformanceCounter pf2 = new PerformanceCounter("Process", "Working Set", ps.ProcessName);
        Console.WriteLine("{0}:{1} {2:N}KB", ps.ProcessName, "工作集(进程类)", ps.WorkingSet64 / 1024);
        Console.WriteLine("{0}:{1} {2:N}KB", ps.ProcessName, "工作集    ", pf2.NextValue() / 1024);
        //私有工作集
        Console.WriteLine("{0}:{1} {2:N}KB", ps.ProcessName, "私有工作集  ", pf1.NextValue() / 1024);

      }

      watch.Stop();
      Console.WriteLine(watch.Elapsed);
      Console.ReadLine();
    }
  }
}

其中,工作集ps.WorkingSet64是静态的,pf2.NextValue()是动态变化的,工作集包含进程运行时其独占的内存和与其他进程共享的内存的和,而私有工作集是只包含进程独占的内存。

下面一组代码可以动态显示本程序所对应的进程的CPU和内存使用率的变化:

首先是SystemInfo.cs类:

using System;
using System.Collections.Generic;
using System.Diagnostics;
using System.Threading;
using System.IO;
using System.Text;
using System.Management;
using System.Runtime.InteropServices;

namespace CSharpPerformance
{
  public class SystemInfo
  {
    private int m_ProcessorCount = 0;  //CPU个数
    private PerformanceCounter pcCpuLoad;  //CPU计数器
    private long m_PhysicalMemory = 0;  //物理内存

    private const int GW_HWNDFIRST = 0;
    private const int GW_HWNDNEXT = 2;
    private const int GWL_STYLE = (-16);
    private const int WS_VISIBLE = 268435456;
    private const int WS_BORDER = 8388608;

    #region AIP声明
    [DllImport("IpHlpApi.dll")]
    extern static public uint GetIfTable(byte[] pIfTable, ref uint pdwSize, bool bOrder);

    [DllImport("User32")]
    private extern static int GetWindow(int hWnd, int wCmd);

    [DllImport("User32")]
    private extern static int GetWindowLongA(int hWnd, int wIndx);

    [DllImport("user32.dll")]
    private static extern bool GetWindowText(int hWnd, StringBuilder title, int maxBufSize);

    [DllImport("user32", CharSet = CharSet.Auto)]
    private extern static int GetWindowTextLength(IntPtr hWnd);
    #endregion

    #region 构造函数
    /// <summary>
    /// 构造函数,初始化计数器等
    /// </summary>
    public SystemInfo()
    {
      //初始化CPU计数器
      pcCpuLoad = new PerformanceCounter("Processor", "% Processor Time", "_Total");
      pcCpuLoad.MachineName = ".";
      pcCpuLoad.NextValue();

      //CPU个数
      m_ProcessorCount = Environment.ProcessorCount;

      //获得物理内存
      ManagementClass mc = new ManagementClass("Win32_ComputerSystem");
      ManagementObjectCollection moc = mc.GetInstances();
      foreach (ManagementObject mo in moc)
      {
        if (mo["TotalPhysicalMemory"] != null)
        {
          m_PhysicalMemory = long.Parse(mo["TotalPhysicalMemory"].ToString());
        }
      }
    }
    #endregion

    #region CPU个数
    /// <summary>
    /// 获取CPU个数
    /// </summary>
    public int ProcessorCount
    {
      get
      {
        return m_ProcessorCount;
      }
    }
    #endregion

    #region CPU占用率
    /// <summary>
    /// 获取CPU占用率
    /// </summary>
    public float CpuLoad
    {
      get
      {
        return pcCpuLoad.NextValue();
      }
    }
    #endregion

    #region 可用内存
    /// <summary>
    /// 获取可用内存
    /// </summary>
    public long MemoryAvailable
    {
      get
      {
        long availablebytes = 0;
        //ManagementObjectSearcher mos = new ManagementObjectSearcher("SELECT * FROM Win32_PerfRawData_PerfOS_Memory");
        //foreach (ManagementObject mo in mos.Get())
        //{
        //  availablebytes = long.Parse(mo["Availablebytes"].ToString());
        //}
        ManagementClass mos = new ManagementClass("Win32_OperatingSystem");
        foreach (ManagementObject mo in mos.GetInstances())
        {
          if (mo["FreePhysicalMemory"] != null)
          {
            availablebytes = 1024 * long.Parse(mo["FreePhysicalMemory"].ToString());
          }
        }
        return availablebytes;
      }
    }
    #endregion

    #region 物理内存
    /// <summary>
    /// 获取物理内存
    /// </summary>
    public long PhysicalMemory
    {
      get
      {
        return m_PhysicalMemory;
      }
    }
    #endregion

    #region 结束指定进程
    /// <summary>
    /// 结束指定进程
    /// </summary>
    /// <param name="pid">进程的 Process ID</param>
    public static void EndProcess(int pid)
    {
      try
      {
        Process process = Process.GetProcessById(pid);
        process.Kill();
      }
      catch { }
    }
    #endregion

    #region 查找所有应用程序标题
    /// <summary>
    /// 查找所有应用程序标题
    /// </summary>
    /// <returns>应用程序标题范型</returns>
    public static List<string> FindAllApps(int Handle)
    {
      List<string> Apps = new List<string>();

      int hwCurr;
      hwCurr = GetWindow(Handle, GW_HWNDFIRST);

      while (hwCurr > 0)
      {
        int IsTask = (WS_VISIBLE | WS_BORDER);
        int lngStyle = GetWindowLongA(hwCurr, GWL_STYLE);
        bool TaskWindow = ((lngStyle & IsTask) == IsTask);
        if (TaskWindow)
        {
          int length = GetWindowTextLength(new IntPtr(hwCurr));
          StringBuilder sb = new StringBuilder(2 * length + 1);
          GetWindowText(hwCurr, sb, sb.Capacity);
          string strTitle = sb.ToString();
          if (!string.IsNullOrEmpty(strTitle))
          {
            Apps.Add(strTitle);
          }
        }
        hwCurr = GetWindow(hwCurr, GW_HWNDNEXT);
      }

      return Apps;
    }
    #endregion
  }
}

然后是执行代码:

using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Diagnostics;
using System.Threading;

namespace CSharpPerformance
{//该程序可以实时监控程序本身对应进程的工作集、私有工作集和CPU使用率
  class Program
  {
    static void Main(string[] args)
    {
      //获取当前进程对象
      Process cur = Process.GetCurrentProcess();

      PerformanceCounter curpcp = new PerformanceCounter("Process", "Working Set - Private", cur.ProcessName);
      PerformanceCounter curpc = new PerformanceCounter("Process", "Working Set", cur.ProcessName);
      PerformanceCounter curtime = new PerformanceCounter("Process", "% Processor Time", cur.ProcessName);

      //上次记录CPU的时间
      TimeSpan prevCpuTime = TimeSpan.Zero;
      //Sleep的时间间隔
      int interval = 1000;

      PerformanceCounter totalcpu = new PerformanceCounter("Processor", "% Processor Time", "_Total");

      SystemInfo sys = new SystemInfo();
      const int KB_DIV = 1024;
      const int MB_DIV = 1024 * 1024;
      const int GB_DIV = 1024 * 1024 * 1024;
      while (true)
      {
        //第一种方法计算CPU使用率
        //当前时间
        TimeSpan curCpuTime = cur.TotalProcessorTime;
        //计算
        double value = (curCpuTime - prevCpuTime).TotalMilliseconds / interval / Environment.ProcessorCount * 100;
        prevCpuTime = curCpuTime;

        Console.WriteLine("{0}:{1} {2:N}KB CPU使用率:{3}", cur.ProcessName, "工作集(进程类)", cur.WorkingSet64 / 1024,value);//这个工作集只是在一开始初始化,后期不变
        Console.WriteLine("{0}:{1} {2:N}KB CPU使用率:{3}", cur.ProcessName, "工作集    ", curpc.NextValue() / 1024,value);//这个工作集是动态更新的
        //第二种计算CPU使用率的方法
        Console.WriteLine("{0}:{1} {2:N}KB CPU使用率:{3}%", cur.ProcessName, "私有工作集  ", curpcp.NextValue() / 1024,curtime.NextValue()/Environment.ProcessorCount);
        //Thread.Sleep(interval);

        //第一种方法获取系统CPU使用情况
        Console.Write("\r系统CPU使用率:{0}%", totalcpu.NextValue());
        //Thread.Sleep(interval);

        //第二章方法获取系统CPU和内存使用情况
        Console.Write("\r系统CPU使用率:{0}%,系统内存使用大小:{1}MB({2}GB)", sys.CpuLoad, (sys.PhysicalMemory - sys.MemoryAvailable) / MB_DIV, (sys.PhysicalMemory - sys.MemoryAvailable) / (double)GB_DIV);
        Thread.Sleep(interval);
      }

      Console.ReadLine();
    }
  }
}

以上程序可以正常运行,没隔1S刷新一次,实现动态显示本程序对应进程的CPU和内存使用情况。

原文链接:http://www.cnblogs.com/maowang1991/p/3285983.html

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持我们。

(0)

相关推荐

  • C#编程获取客户端计算机硬件及系统信息功能示例

    本文实例讲述了C#编程获取客户端计算机硬件及系统信息功能.分享给大家供大家参考,具体如下: 这里使用C#获取客户端计算机硬件及系统信息 ,包括CPU.硬盘.IP.MAC地址.操作系统等. 1.项目引用System.Management库. 2.创建HardwareHandler.cs类文件 using System; using System.Collections.Generic; using System.Linq; using System.Text; using System.Manag

  • C#获取CPU编号的方法

    本文实例讲述了C#获取CPU编号的方法.分享给大家供大家参考.具体如下: /// <summary> /// Gets the cpu 编号. ///需引用 using System.Management; /// </summary> /// <returns></returns> public string GetCpuId() { string cpuInfo = ""; ManagementClass cimobject = ne

  • C#测量程序运行时间及cpu使用时间实例方法

    这里要指出的是, 运行一段程序,使用的cpu时间,跟实际运行的时间是不一样的.附例如下: 复制代码 代码如下: private void ShowRunTime()  {   TimeSpan ts1 = Process.GetCurrentProcess().TotalProcessorTime;   Stopwatch stw = new Stopwatch();  stw.Start();  int Circles = 1000;   for (int i = 0; i < Circles

  • C#编程获取各种电脑硬件信息的方法示例

    本文实例讲述了C#编程获取各种电脑硬件信息的方法.分享给大家供大家参考,具体如下: 获取CPU编号: ManagementClass mc = new ManagementClass("Win32_Processor"); ManagementObjectCollection moc = mc.GetInstances(); string strID = null ; foreach( ManagementObject mo in moc ) { strID = mo.Properti

  • C#利用win32 Api 修改本地系统时间、获取硬盘序列号

    C#利用win32 Api 修改本地系统时间.获取硬盘序列号,可以用于软件注册机制的编写! 复制代码 代码如下: using System; using System.Collections.Generic; using System.Text; using System.Runtime.InteropServices; namespace Fengyun {     public class Win32     {         #region 修改本地系统时间         [DllIm

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

    利用C#获取计算机名,IP,MAC信息,如下为源代码: 复制代码 代码如下: using System; using System.Collections.Generic; using System.Text; using System.Net; using System.Management; namespace Wenanry.Net { /// <summary> /// 获取计算机系统信息 /// </summary> public class ManagementSyst

  • C#获取机器码的方法详解(机器名,CPU编号,硬盘编号,网卡mac等)

    本文实例讲述了C#获取机器码的方法.分享给大家供大家参考,具体如下: using System.Runtime.InteropServices; using System.Management; using System; public class HardwareInfo { //取机器名 public string GetHostName() { return System.Net.Dns.GetHostName(); } //取CPU编号 public String GetCpuID()

  • C#如何取硬件标志

    using System; using System.Runtime.InteropServices; using  System.Management; namespace Hardware { /// <summary> /// Hardware_Mac 的摘要说明. /// </summary> public class HardwareInfo {   //取机器名    public string GetHostName()   {    return System.Ne

  • 用C#获取硬盘序列号,CPU序列号,网卡MAC地址的源码

    privatestring[]GetMoc() { string[]str=newstring[3]; ManagementClassmcCpu=newManagementClass("win32_Processor"); ManagementObjectCollectionmocCpu=mcCpu.GetInstances(); foreach(ManagementObjectminmocCpu) { str[0]=m["ProcessorId"].ToStrin

  • C#读取计算机CPU及HDD信息的方法

    本文实例讲述了C#读取计算机CPU及HDD信息的方法.分享给大家供大家参考.具体如下: 这里使用C#读取计算机CPU,HDD信息,适用于Windows public string getCpuInfo() //读取CPU信息 { ManagementClass mobj = new ManagementClass("Win32_Processor"); ManagementObjectCollection moc = mobj.GetInstances(); foreach (Mana

  • C#获取硬盘编号的方法

    本文实例讲述了C#获取硬盘编号的方法.分享给大家供大家参考.具体实现方法如下: ManagementClass mc = new ManagementClass("Win32_PhysicalMedia"); //Win32_DiskDrive不包含SerialNumber属性. ManagementObjectCollection moc = mc.GetInstances(); string strID = null ; foreach( ManagementObject mo i

随机推荐