2010-03-25 70 views
6

我需要记录用户有多少内存的信息。我的第一个方法是使用GlobalMemoryStatusEx,但只给了我多少内存可用于Windows,而不是多少安装。我发现这个函数Ge​​tPhysicallyInstalledSystemMemory,但它只有Vista和更高版本。我需要这个在XP上工作。是否有一种相当简单的方法来查询GetPhysicallyInstalledSystemMemory正在使用的SMBIOS信息,或者是否存在我可以找到的某处的注册表值。如何找出在Windows中物理安装了多少内存?

回答

2

编辑:我会用steelbytes'的答案,但如果你不能使用WMI出于某种原因,你可以这样做:

我不相信Vista之前的Windows版本会跟踪这些信息 - 您必须执行一些系统特定的BIOS或主板枚举才能找到Vista之前的真实值。您最好的选择是调用新的API GetPhysicallyInstalledSystemMemory,并将故障转移到XP系统的GlobalMemoryStatusEx

1

GlobalMemoryStatusEx返回的值之一是ullTotalPhys,这似乎是你正在寻找的。

像用于视频内存的内存不在那里,但我怀疑有一种方法可以达到这一点。

+0

为什么这个答案被upvoted?它只是用不同的词语来重述这个问题。 – 2010-03-25 14:43:32

4

您应该查看Win32_ComputerSystem类(WMI)和TotalPhysicalMemory属性。有许多方法可以通过.Net通过System.Management命名空间为托管代码访问这些信息(我使用C#,所以我没有尝试使用Visual Studio for C++开发自己)。你也可以创建一个脚本来直接运行WMI并让你的C++程序调用脚本。

更新:您也可以看看Win32_PhysicalMemory类(看一下Capacity属性)。这将使用一些RAM等的缓解读数不准确由于BIOS

更新2:

我在C#(3.5)和Windows XP(SP 2)和它的作品尝试过这一点。我相信你可以在C++中使用相同的WMI类(至少通过Visual Studio)做类似的事情。它没有问题,所以它不是一个Vista或更大的问题。我不确定这是否正是您正在寻找的内容,但此代码将返回系统的总物理内存容量(而不是多少空闲)。希望这是你的意思。反正这里是定位的RAM中的每个杆,并显示有关每一个(包括容量)的一些信息一些示例代码,然后将总在底部:

using System; 
using System.Collections.Generic; 
using System.Management; 
using System.Text; 

namespace WmiTest 
{ 
    public class RamCounter 
    { 
     private List<RamStick> _ramSticks; 
     private int _totalRam; 
     private StringBuilder _stringRepresentation; 

     public RamCounter() 
     { 
      _ramSticks = new List<RamStick>(); 
      _totalRam = 0; 
      _stringRepresentation = new StringBuilder(); 
     } 

     public void GetRamSticks() 
     { 
      _ramSticks.Clear(); 
      _totalRam = 0; 

      ManagementObjectSearcher searcher = new ManagementObjectSearcher("SELECT * FROM Win32_PhysicalMemory"); 
      ManagementObjectCollection queryCollection = searcher.Get(); 

      foreach (ManagementObject mo in queryCollection) 
      { 
       _ramSticks.Add(
        new RamStick(Convert.ToUInt64(mo.GetPropertyValue("Capacity")), 
           mo.GetPropertyValue("DeviceLocator").ToString(), 
           mo.GetPropertyValue("Description").ToString(), 
           Convert.ToUInt32(mo.GetPropertyValue("FormFactor")), 
           Convert.ToUInt32(mo.GetPropertyValue("Speed")))); 
      } 
     } 

     public override string ToString() 
     { 
      _stringRepresentation.Capacity = 0; 

      foreach (RamStick rs in _ramSticks) 
      { 
       _stringRepresentation.Append(rs.ToString()); 
       _totalRam += rs.CapacityInMB; 
      } 

      _stringRepresentation.Append("Total RAM(MB): " + _totalRam); 
      return _stringRepresentation.ToString(); 
     } 
    } 

    public class RamStick 
    { 
     private UInt64 _capacity; 
     private UInt32 _formFactor; 

     public RamStick(UInt64 capacity, string location, string description, UInt32 formFactor, UInt32 speed) 
     { 
      _capacity = capacity; 
      Location = location; 
      Description = description; 
      _formFactor = formFactor; 
      Speed = speed; 
     } 

     public int CapacityInMB 
     { 
      get { return Convert.ToInt32(_capacity/(1024 * 1024)); } 
     } 

     public string Location 
     { 
      get; 
      private set; 
     } 

     public string Description 
     { 
      get; 
      private set; 
     } 

     public string GetFormFactor() 
     { 
      string formFactor = string.Empty; 

      switch (_formFactor) 
      { 
       case 1: 
        formFactor = "Other"; 
        break; 

       case 2: 
        formFactor = "SIP"; 
        break; 

       case 3: 
        formFactor = "DIP"; 
        break; 

       case 4: 
        formFactor = "ZIP"; 
        break; 

       case 5: 
        formFactor = "SOJ"; 
        break; 

       case 6: 
        formFactor = "Proprietary"; 
        break; 

       case 7: 
        formFactor = "SIMM"; 
        break; 

       case 8: 
        formFactor = "DIMM"; 
        break; 

       case 9: 
        formFactor = "TSOP"; 
        break; 

       case 10: 
        formFactor = "PGA"; 
        break; 

       case 11: 
        formFactor = "RIMM"; 
        break; 

       case 12: 
        formFactor = "SODIMM"; 
        break; 

       case 13: 
        formFactor = "SRIMM"; 
        break; 

       case 14: 
        formFactor = "SMD"; 
        break; 

       case 15: 
        formFactor = "SSMP"; 
        break; 

       case 16: 
        formFactor = "QFP"; 
        break; 

       case 17: 
        formFactor = "TQFP"; 
        break; 

       case 18: 
        formFactor = "SOIC"; 
        break; 

       case 19: 
        formFactor = "LCC"; 
        break; 

       case 20: 
        formFactor = "PLCC"; 
        break; 

       case 21: 
        formFactor = "BGA"; 
        break; 

       case 22: 
        formFactor = "FPBGA"; 
        break; 

       case 23: 
        formFactor = "LGA"; 
        break; 

       default: 
        formFactor = "Unknown"; 
        break; 
      } 

      return formFactor; 
     } 

     public UInt32 Speed 
     { 
      get; 
      private set; 
     } 

     public override string ToString() 
     { 
      return string.Format("Description:{1}{0}" 
           + "Location:{2}{0}" 
           + "Form Factor:{3}{0}" 
           + "Speed:{4}{0}" 
           + "Capacity(MB):{5}{0}{0}", 

           Environment.NewLine, 
           Description, 
           Location, 
           GetFormFactor(), 
           Speed, 
           CapacityInMB); 
     } 
    } 
} 

要使用的代码:

private void btnRam_Click(object sender, EventArgs e) 
{ 
    RamCounter rc = new RamCounter(); 
    rc.GetRamSticks(); 
    MessageBox.Show(rc.ToString()); 
} 

来自我的机器的示例输出:

Description: Physical Memory 
Location: J6H1 
Format Factor: DIMM 
Speed: 667 
Capacity(MB): 1024 

Description: Physical Memory 
Location: J6H2 
Format Factor: DIMM 
Speed: 667 
Capacity(MB): 1024 

Description: Physical Memory 
Location: J6J1 
Format Factor: DIMM 
Speed: 667 
Capacity(MB): 1024 

Total RAM(MB): 3072 
+0

这与GlobalMemoryStatusEx调用有相同的问题。 – 2010-03-25 14:44:24

+0

许多属性声明它们是否在特定版本的Windows(或特定版本之前)中不受支持。我提到的这些属性都没有说明它们只是Vista或更高版本。这并不是说他们在XP支持,但(没有尝试过自己)。 – 2010-03-25 15:03:22

+0

我怀疑Win32_ComputerSystem内的调用简单归结为GlobalMemoryStatusEx调用。但Win32_PhysicalMemory枚举应该适用于所有系统。 +1进行更新。 – 2010-04-08 13:58:24

相关问题