1

我正在尝试列出给定进程的所有子进程(给定它的进程 ID)。经过一些研究,我得出了这个结论:

static void Main(string[] args)
{
    listChildProcesses(0);
    Console.ReadKey();
}

public static void listChildProcesses(int parentProcessId)
{
    String myQuery = string.Format("select * from win32_process where ParentProcessId={0}", parentProcessId);
    ObjectQuery objQuery = new ObjectQuery(myQuery);
    ManagementObjectSearcher objSearcher = new ManagementObjectSearcher(objQuery);
    ManagementObjectCollection processList = objSearcher.Get();

    foreach (ManagementObject item in processList)
    {
        try
        {
            int processId = Convert.ToInt32(item["ProcessId"].ToString());

            Console.WriteLine("processId:{0} name:{1} {2}",
                item["ProcessId"],
                item["Name"],
                item["ParentProcessId"]
            );

            // recursive call
            if (processId != parentProcessId)
                listChildProcesses(processId);
        }
        catch (Exception e)
        {
            Console.WriteLine("Error: " + e);
        }
    }
}

我希望这可以让我显示所有进程(因为该方法从 PID=0 开始,然后在从那里找到的每个 PID 上递归调用)。

但这是我在 Windows 8 (x86) 上得到的输出:

processId:0 name:System Idle Process 0
processId:4 name:System 0 
processId:300 name:smss.exe 4 

它停在那里。我希望它会继续与 System 的每个孩子一起继续,然后是这些孩子的每个孩子。

4

1 回答 1

2

你没有做你想做的事...

这样你就只是列出孩子。而你正在通过“0”访问空闲的。

尝试这样的事情来获取所有进程......

ManagementClass mngcls = new ManagementClass("Win32_Process");
foreach (ManagementObject instance in mngcls.GetInstances())
{
    Console.Write("ID: " + instance["ProcessId"]);
}

……那你在做什么。

于 2013-03-26T18:09:49.167 回答