performancecounter уроки - C#Использовать память в%




уменьшить размер (5)

Я создал PerformanceCounter, который может проверить общее использование памяти в%, но проблема в том, что она не дает мне того же значения, что и в диспетчере задач показывает мне. например: моя программа говорит 34%, но менеджер задач говорит 40%.

Есть идеи?

ЗАМЕТКА
Я пытаюсь получить доступную ОЗУ системы, а не используемую ОЗУ процессом.

Текущий код

private PerformanceCounter performanceCounterRAM = new PerformanceCounter();

performanceCounterRAM.CounterName = "% Committed Bytes In Use";
performanceCounterRAM.CategoryName = "Memory";

progressBarRAM.Value = (int)(performanceCounterRAM.NextValue());
            labelRAM.Text = "RAM: " + progressBarRAM.Value.ToString(CultureInfo.InvariantCulture) + "%";

РЕДАКТИРОВАТЬ
Я обновляю индикатор прогресса и метку каждую секунду таймером.


Answers

Счетчики производительности - это не очень хорошая идея. Используйте этот код, чтобы получить% от использования памяти из диспетчера задач

var wmiObject = new ManagementObjectSearcher("select * from Win32_OperatingSystem");

var memoryValues = wmiObject.Get().Cast<ManagementObject>().Select(mo => new {
    FreePhysicalMemory = Double.Parse(mo["FreePhysicalMemory"].ToString()),
    TotalVisibleMemorySize = Double.Parse(mo["TotalVisibleMemorySize"].ToString())
}).FirstOrDefault();

if (memoryValues != null) {
    var percent = ((memoryValues.TotalVisibleMemorySize - memoryValues.FreePhysicalMemory) / memoryValues.TotalVisibleMemorySize) * 100;
}

Я думаю, что процент физической памяти, указанный диспетчером задач, на самом деле является другим показателем для % Committed Bytes In Use вашим PerformanceCounter.

На моей машине существует явная разница в 20% между этими значениями при просмотре на мониторе производительности:

В этой статье показано, что метка% Committed Bytes учитывает размер файла подкачки, а не только физическую память устройства. Это объясняет, почему это значение постоянно ниже, чем значение Task Manager.

Возможно, вам удастся подсчитать процент, используя Memory \ Available Bytes , но я не уверен, как получить общий объем физической памяти от PerformanceCounter.


Вы можете использовать API окон GetPerformanceInfo, он показывает точно такие же значения, как Windows Task Manager в Windows 7, вот консольное приложение, которое получает доступную физическую память, вы можете легко получить другую информацию, возвращаемую GetPerformanceInfo, обратитесь к документации по структуре MSDN PERFORMANCE_INFORMATION чтобы узнать, как для вычисления значения в MiB, в основном все значения SIZE_T находятся на страницах, поэтому вы должны умножить его на PageSize.

Обновление: я обновил этот код, чтобы показать процент, это не оптимально, потому что он вызывает GetPerformanceInfo два раза, но я надеюсь, что вы получите эту идею.

using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Runtime.InteropServices;

namespace ConsoleApplicationPlayground
{
  class Program
  {
    static void Main(string[] args)
    {
      while (true)
      {
        Int64 phav = PerformanceInfo.GetPhysicalAvailableMemoryInMiB();
        Int64 tot = PerformanceInfo.GetTotalMemoryInMiB();
        decimal percentFree = ((decimal)phav / (decimal)tot) * 100;
        decimal percentOccupied = 100 - percentFree;
        Console.WriteLine("Available Physical Memory (MiB) " + phav.ToString());
        Console.WriteLine("Total Memory (MiB) " + tot.ToString());
        Console.WriteLine("Free (%) " + percentFree.ToString());
        Console.WriteLine("Occupied (%) " + percentOccupied.ToString());
        Console.ReadLine();
      }
    }
  }

  public static class PerformanceInfo
  {
    [DllImport("psapi.dll", SetLastError = true)]
    [return: MarshalAs(UnmanagedType.Bool)]
    public static extern bool GetPerformanceInfo([Out] out PerformanceInformation PerformanceInformation, [In] int Size);

    [StructLayout(LayoutKind.Sequential)]
    public struct PerformanceInformation
    {
      public int Size;
      public IntPtr CommitTotal;
      public IntPtr CommitLimit;
      public IntPtr CommitPeak;
      public IntPtr PhysicalTotal;
      public IntPtr PhysicalAvailable;
      public IntPtr SystemCache;
      public IntPtr KernelTotal;
      public IntPtr KernelPaged;
      public IntPtr KernelNonPaged;
      public IntPtr PageSize;
      public int HandlesCount;
      public int ProcessCount;
      public int ThreadCount;
    }

    public static Int64 GetPhysicalAvailableMemoryInMiB()
    {
        PerformanceInformation pi = new PerformanceInformation();
        if (GetPerformanceInfo(out pi, Marshal.SizeOf(pi)))
        {
          return Convert.ToInt64((pi.PhysicalAvailable.ToInt64() * pi.PageSize.ToInt64() / 1048576));
        }
        else
        {
          return -1;
        }

    }

    public static Int64 GetTotalMemoryInMiB()
    {
      PerformanceInformation pi = new PerformanceInformation();
      if (GetPerformanceInfo(out pi, Marshal.SizeOf(pi)))
      {
        return Convert.ToInt64((pi.PhysicalTotal.ToInt64() * pi.PageSize.ToInt64() / 1048576));
      }
      else
      {
        return -1;
      }

    }
  }
}

Вы можете использовать «show description» в нижней части монитора производительности. Цитировать

% Committed Bytes In Use - отношение памяти \ Committed Bytes к пределу памяти \ Commit Limit. Committed memory - используемая физическая память, для которой пространство зарезервировано в файле подкачки, если оно необходимо записать на диск. Предел фиксации определяется размером файла подкачки. Если файл подкачки увеличен, предел фиксации увеличивается, а отношение уменьшается). Этот счетчик отображает только текущее процентное значение; это не среднее.

Soo PM PM использует файл подкачки, в то время как TM использует реальную ОЗУ.


Существует одно отличие: вы не можете использовать String без using System; заранее.





c# performancecounter