how to get the CPU and memory usage in VB 6 code? Thanks!
Here's how to get your RAM information:
You can take the code below and just drop it into a form. I'm leaving error handling to you since I expect you will want to just use this as an example. There is also a function to convert a 64 bit integer to a VB double, and a function to format the number in KB, MB, and GB.
Private Declare Sub GlobalMemoryStatusEx Lib "kernel32" (lpBuffer As MEMORYSTATUSEX)
Private Type INT64
LoPart As Long
HiPart As Long
End Type
Private Type MEMORYSTATUSEX
dwLength As Long
dwMemoryLoad As Long
ulTotalPhys As INT64
ulAvailPhys As INT64
ulTotalPageFile As INT64
ulAvailPageFile As INT64
ulTotalVirtual As INT64
ulAvailVirtual As INT64
ulAvailExtendedVirtual As INT64
End Type
Private Sub Form_Load()
Me.AutoRedraw = True
Call PrintRamInformation
End Sub
Private Sub PrintRamInformation()
Dim udtMemStatEx As MEMORYSTATUSEX
Me.Cls
udtMemStatEx.dwLength = Len(udtMemStatEx)
Call GlobalMemoryStatusEx(udtMemStatEx)
Me.Print "Total physical memory" + vbTab + NumberInKB(CLargeInt(udtMemStatEx.ulTotalPhys.LoPart, udtMemStatEx.ulTotalPhys.HiPart)) & " (" & Round(CLargeInt(udtMemStatEx.ulAvailPhys.LoPart, udtMemStatEx.ulAvailPhys.HiPart) / (CLargeInt(udtMemStatEx.ulTotalPhys.LoPart, udtMemStatEx.ulTotalPhys.HiPart)) * 100) & "% Free)"
Me.Print "Available physical memory" + vbTab + NumberInKB(CLargeInt(udtMemStatEx.ulAvailPhys.LoPart, udtMemStatEx.ulAvailPhys.HiPart))
Me.Print "Total virtual memory" + vbTab + NumberInKB(CLargeInt(udtMemStatEx.ulTotalVirtual.LoPart, udtMemStatEx.ulTotalVirtual.HiPart))
Me.Print "Available virtual memory" + vbTab + NumberInKB(CLargeInt(udtMemStatEx.ulAvailVirtual.LoPart, udtMemStatEx.ulAvailVirtual.HiPart))
Me.Print "Total page file" + vbTab + NumberInKB(CLargeInt(udtMemStatEx.ulTotalPageFile.LoPart, udtMemStatEx.ulTotalPageFile.HiPart))
Me.Print "Available page file" + vbTab + NumberInKB(CLargeInt(udtMemStatEx.ulAvailPageFile.LoPart, udtMemStatEx.ulAvailPageFile.HiPart))
Me.Print "Available extended page file" + vbTab + NumberInKB(CLargeInt(udtMemStatEx.ulAvailExtendedVirtual.LoPart, udtMemStatEx.ulAvailExtendedVirtual.HiPart))
Me.Print "Memory Load" + vbTab + CStr(udtMemStatEx.dwMemoryLoad) + "%"
End Sub
'This function converts the LARGE_INTEGER data type to a double
Private Function CLargeInt(Lo As Long, Hi As Long) As Double
Dim dblLo As Double
Dim dblHi As Double
If Lo < 0 Then
dblLo = 2 ^ 32 + Lo
Else
dblLo = Lo
End If
If Hi < 0 Then
dblHi = 2 ^ 32 + Hi
Else
dblHi = Hi
End If
CLargeInt = dblLo + dblHi * 2 ^ 32
End Function
Public Function NumberInKB(ByVal vNumber As Currency) As String
Dim strReturn As String
Select Case vNumber
Case Is < 1024 ^ 1
strReturn = CStr(vNumber) & " bytes"
Case Is < 1024 ^ 2
strReturn = CStr(Round(vNumber / 1024, 1)) & " KB"
Case Is < 1024 ^ 3
strReturn = CStr(Round(vNumber / 1024 ^ 2, 2)) & " MB"
Case Is < 1024 ^ 4
strReturn = CStr(Round(vNumber / 1024 ^ 3, 2)) & " GB"
End Select
NumberInKB = strReturn
End Function