我试图填充一个列表框,其中包含所有正在运行的应用程序的列表(我正在使用C ++ Builder)并通过搜索我发现这个代码没有给我一个正在运行的应用程序的列表,它会打印一些不需要的文本和运行应用程序
#include <windows.h>
#include <stdio.h>
#include <tchar.h>
#include <psapi.h>
void PrintProcessNameAndID( DWORD processID )
{
TCHAR szProcessName[MAX_PATH] = TEXT("<unknown>");
HANDLE hProcess = OpenProcess( PROCESS_QUERY_INFORMATION |
PROCESS_VM_READ,
FALSE, processID );
if (NULL != hProcess )
{
HMODULE hMod;
DWORD cbNeeded;
if ( EnumProcessModules( hProcess, &hMod, sizeof(hMod),
&cbNeeded) )
{
GetModuleBaseName( hProcess, hMod, szProcessName,
sizeof(szProcessName)/sizeof(TCHAR) );
}
}
_tprintf( TEXT("%s (PID: %u)\n"), szProcessName, processID );
CloseHandle( hProcess );
}
int main( void )
{
DWORD aProcesses[1024], cbNeeded, cProcesses;
unsigned int i;
if ( !EnumProcesses( aProcesses, sizeof(aProcesses), &cbNeeded ) )
{
return 1;
}
cProcesses = cbNeeded / sizeof(DWORD);
for ( i = 0; i < cProcesses; i++ )
{
if( aProcesses[i] != 0 )
{
PrintProcessNameAndID( aProcesses[i] );
}
}
return 0;
}
我知道这段代码适用于控制台应用程序,但是如果它有效,我会编辑它以在c ++ builder上运行,但它只是不行。 那么什么是正确的代码?
答案 0 :(得分:0)
该代码应该适用于所有进程,而不仅仅是控制台进程。可能有多个模块,所以从技术上来说应该是(我网站上的旧ANSI代码):
HANDLE hProc;
char szProcessName [80];
HMODULE ahMod [10];
DWORD dwNeeded;
hProc = OpenProcess (PROCESS_QUERY_INFORMATION|PROCESS_VM_READ,
FALSE,
dwPid);
if (hProc)
{
if (EnumProcessModules (hProc,
ahMod,
sizeof(ahMod),
&dwNeeded))
{
if (GetModuleBaseName (hProc,
ahMod[0],
szProcessName,
sizeof(szProcessName)))
{
<success>
}
else
{
<failure>
}
}
CloseHandle (hProc);
}
同样正如雷蒙德指出的那样,你的循环基于你的数组的大小(这将解释垃圾)。这可能是由于EnumProcesses的MS帮助,它讨论了将数组大小除以DWORD的大小,但这只是为了检测函数是否已填满您的数组,并且您需要重新提交更多空间。我猜你应该在调用EnumProcesses之前将你的进程数组清零,即使用memset(或ZeroMemory,如果C ++ builder支持那个宏)。