Process.GetProcesses Methode
Definitie
Belangrijk
Bepaalde informatie heeft betrekking op een voorlopige productversie die aanzienlijk kan worden gewijzigd voordat deze wordt uitgebracht. Microsoft biedt geen enkele expliciete of impliciete garanties met betrekking tot de informatie die hier wordt verstrekt.
Hiermee maakt u een matrix met nieuwe Process onderdelen en koppelt u deze aan bestaande procesbronnen.
Overloads
| Name | Description |
|---|---|
| GetProcesses() |
Hiermee maakt u een nieuw Process onderdeel voor elke procesresource op de lokale computer. |
| GetProcesses(String) |
Hiermee maakt u een nieuw Process onderdeel voor elke procesresource op de opgegeven computer. |
GetProcesses()
Hiermee maakt u een nieuw Process onderdeel voor elke procesresource op de lokale computer.
public:
static cli::array <System::Diagnostics::Process ^> ^ GetProcesses();
public static System.Diagnostics.Process[] GetProcesses();
static member GetProcesses : unit -> System.Diagnostics.Process[]
Public Shared Function GetProcesses () As Process()
Retouren
Een matrix van het type Process dat alle procesbronnen vertegenwoordigt die op de lokale computer worden uitgevoerd.
Voorbeelden
In het volgende voorbeeld wordt informatie opgehaald over het huidige proces, processen die worden uitgevoerd op de lokale computer, alle exemplaren van Kladblok die op de lokale computer worden uitgevoerd en een specifiek proces op de lokale computer. Vervolgens worden gegevens opgehaald voor dezelfde processen op een externe computer.
using System;
using System.Diagnostics;
using System.ComponentModel;
namespace MyProcessSample
{
class MyProcess
{
void BindToRunningProcesses()
{
// Get the current process.
Process currentProcess = Process.GetCurrentProcess();
// Get all processes running on the local computer.
Process[] localAll = Process.GetProcesses();
// Get all instances of Notepad running on the local computer.
// This will return an empty array if notepad isn't running.
Process[] localByName = Process.GetProcessesByName("notepad");
// Get a process on the local computer, using the process id.
// This will throw an exception if there is no such process.
Process localById = Process.GetProcessById(1234);
// Get processes running on a remote computer. Note that this
// and all the following calls will timeout and throw an exception
// if "myComputer" and 169.0.0.0 do not exist on your local network.
// Get all processes on a remote computer.
Process[] remoteAll = Process.GetProcesses("myComputer");
// Get all instances of Notepad running on the specific computer, using machine name.
Process[] remoteByName = Process.GetProcessesByName("notepad", "myComputer");
// Get all instances of Notepad running on the specific computer, using IP address.
Process[] ipByName = Process.GetProcessesByName("notepad", "169.0.0.0");
// Get a process on a remote computer, using the process id and machine name.
Process remoteById = Process.GetProcessById(2345, "myComputer");
}
static void Main()
{
MyProcess myProcess = new MyProcess();
myProcess.BindToRunningProcesses();
}
}
}
open System.Diagnostics
// Get the current process.
let currentProcess = Process.GetCurrentProcess()
// Get all processes running on the local computer.
let localAll = Process.GetProcesses()
// Get all instances of Notepad running on the local computer.
// This will return an empty array if notepad isn't running.
let localByName = Process.GetProcessesByName "notepad"
// Get a process on the local computer, using the process id.
// This will throw an exception if there is no such process.
let localById = Process.GetProcessById 1234
// Get processes running on a remote computer. Note that this
// and all the following calls will timeout and throw an exception
// if "myComputer" and 169.0.0.0 do not exist on your local network.
// Get all processes on a remote computer.
let remoteAll = Process.GetProcesses "myComputer"
// Get all instances of Notepad running on the specific computer, using machine name.
let remoteByName = Process.GetProcessesByName("notepad", "myComputer")
// Get all instances of Notepad running on the specific computer, using IP address.
let ipByName = Process.GetProcessesByName("notepad", "169.0.0.0")
// Get a process on a remote computer, using the process id and machine name.
let remoteById = Process.GetProcessById(2345, "myComputer")
Imports System.Diagnostics
Imports System.ComponentModel
Namespace MyProcessSample
Class MyProcess
Sub BindToRunningProcesses()
' Get the current process. You can use currentProcess from this point
' to access various properties and call methods to control the process.
Dim currentProcess As Process = Process.GetCurrentProcess()
' Get all processes running on the local computer.
Dim localAll As Process() = Process.GetProcesses()
' Get all instances of Notepad running on the local computer.
' This will return an empty array if notepad isn't running.
Dim localByName As Process() = Process.GetProcessesByName("notepad")
' Get a process on the local computer, using the process id.
' This will throw an exception if there is no such process.
Dim localById As Process = Process.GetProcessById(1234)
' Get processes running on a remote computer. Note that this
' and all the following calls will timeout and throw an exception
' if "myComputer" and 169.0.0.0 do not exist on your local network.
' Get all processes on a remote computer.
Dim remoteAll As Process() = Process.GetProcesses("myComputer")
' Get all instances of Notepad running on the specific computer, using machine name.
Dim remoteByName As Process() = Process.GetProcessesByName("notepad", "myComputer")
' Get all instances of Notepad running on the specific computer, using IP address.
Dim ipByName As Process() = Process.GetProcessesByName("notepad", "169.0.0.0")
' Get a process on a remote computer, using the process id and machine name.
Dim remoteById As Process = Process.GetProcessById(2345, "myComputer")
End Sub
Shared Sub Main()
Dim myProcess As New MyProcess()
myProcess.BindToRunningProcesses()
End Sub
End Class
End Namespace 'MyProcessSample
Opmerkingen
Gebruik deze methode om een matrix met nieuwe Process onderdelen te maken en deze te koppelen aan alle procesbronnen op de lokale computer. De procesbronnen moeten al bestaan op de lokale computer, omdat GetProcesses er geen systeembronnen worden gemaakt, maar resources worden gekoppeld aan door de toepassing gegenereerde Process onderdelen. Omdat het besturingssysteem zelf achtergrondprocessen uitvoert, is deze matrix nooit leeg.
Als u niet alle processen wilt ophalen die op de computer worden uitgevoerd, kunt u het aantal beperken met behulp van de GetProcessById of GetProcessesByName methode. GetProcessById maakt een Process onderdeel dat is gekoppeld aan het proces dat op het systeem is geïdentificeerd door de proces-id die u doorgeeft aan de methode. GetProcessesByName maakt een matrix met Process onderdelen waarvan de bijbehorende procesbronnen het uitvoerbare bestand delen dat u doorgeeft aan de methode.
Note
Meerdere Windows-services kunnen worden geladen binnen hetzelfde exemplaar van het servicehostproces (svchost.exe). GetProcesses identificeert deze afzonderlijke services niet; voor dat, zie GetServices.
Zie ook
Van toepassing op
GetProcesses(String)
Hiermee maakt u een nieuw Process onderdeel voor elke procesresource op de opgegeven computer.
public:
static cli::array <System::Diagnostics::Process ^> ^ GetProcesses(System::String ^ machineName);
public static System.Diagnostics.Process[] GetProcesses(string machineName);
static member GetProcesses : string -> System.Diagnostics.Process[]
Public Shared Function GetProcesses (machineName As String) As Process()
Parameters
- machineName
- String
De computer van waaruit de lijst met processen moet worden gelezen.
Retouren
Een matrix van het type Process dat alle procesbronnen vertegenwoordigt die op de opgegeven computer worden uitgevoerd.
Uitzonderingen
De syntaxis van de machineName parameter is ongeldig. Het kan lengte nul (0) hebben.
De machineName parameter is null.
Het besturingssysteemplatform biedt geen ondersteuning voor deze bewerking op externe computers.
Er zijn problemen met het openen van de PRESTATIEmeteritems-API's die worden gebruikt om procesinformatie op te halen. Deze uitzondering is specifiek voor Windows NT, Windows 2000 en Windows XP.
Er is een probleem opgetreden bij het openen van een onderliggende systeem-API.
Voorbeelden
In het volgende voorbeeld wordt informatie opgehaald over het huidige proces, processen die worden uitgevoerd op de lokale computer, alle exemplaren van Kladblok die op de lokale computer worden uitgevoerd en een specifiek proces op de lokale computer. Vervolgens worden gegevens opgehaald voor dezelfde processen op een externe computer.
using System;
using System.Diagnostics;
using System.ComponentModel;
namespace MyProcessSample
{
class MyProcess
{
void BindToRunningProcesses()
{
// Get the current process.
Process currentProcess = Process.GetCurrentProcess();
// Get all processes running on the local computer.
Process[] localAll = Process.GetProcesses();
// Get all instances of Notepad running on the local computer.
// This will return an empty array if notepad isn't running.
Process[] localByName = Process.GetProcessesByName("notepad");
// Get a process on the local computer, using the process id.
// This will throw an exception if there is no such process.
Process localById = Process.GetProcessById(1234);
// Get processes running on a remote computer. Note that this
// and all the following calls will timeout and throw an exception
// if "myComputer" and 169.0.0.0 do not exist on your local network.
// Get all processes on a remote computer.
Process[] remoteAll = Process.GetProcesses("myComputer");
// Get all instances of Notepad running on the specific computer, using machine name.
Process[] remoteByName = Process.GetProcessesByName("notepad", "myComputer");
// Get all instances of Notepad running on the specific computer, using IP address.
Process[] ipByName = Process.GetProcessesByName("notepad", "169.0.0.0");
// Get a process on a remote computer, using the process id and machine name.
Process remoteById = Process.GetProcessById(2345, "myComputer");
}
static void Main()
{
MyProcess myProcess = new MyProcess();
myProcess.BindToRunningProcesses();
}
}
}
open System.Diagnostics
// Get the current process.
let currentProcess = Process.GetCurrentProcess()
// Get all processes running on the local computer.
let localAll = Process.GetProcesses()
// Get all instances of Notepad running on the local computer.
// This will return an empty array if notepad isn't running.
let localByName = Process.GetProcessesByName "notepad"
// Get a process on the local computer, using the process id.
// This will throw an exception if there is no such process.
let localById = Process.GetProcessById 1234
// Get processes running on a remote computer. Note that this
// and all the following calls will timeout and throw an exception
// if "myComputer" and 169.0.0.0 do not exist on your local network.
// Get all processes on a remote computer.
let remoteAll = Process.GetProcesses "myComputer"
// Get all instances of Notepad running on the specific computer, using machine name.
let remoteByName = Process.GetProcessesByName("notepad", "myComputer")
// Get all instances of Notepad running on the specific computer, using IP address.
let ipByName = Process.GetProcessesByName("notepad", "169.0.0.0")
// Get a process on a remote computer, using the process id and machine name.
let remoteById = Process.GetProcessById(2345, "myComputer")
Imports System.Diagnostics
Imports System.ComponentModel
Namespace MyProcessSample
Class MyProcess
Sub BindToRunningProcesses()
' Get the current process. You can use currentProcess from this point
' to access various properties and call methods to control the process.
Dim currentProcess As Process = Process.GetCurrentProcess()
' Get all processes running on the local computer.
Dim localAll As Process() = Process.GetProcesses()
' Get all instances of Notepad running on the local computer.
' This will return an empty array if notepad isn't running.
Dim localByName As Process() = Process.GetProcessesByName("notepad")
' Get a process on the local computer, using the process id.
' This will throw an exception if there is no such process.
Dim localById As Process = Process.GetProcessById(1234)
' Get processes running on a remote computer. Note that this
' and all the following calls will timeout and throw an exception
' if "myComputer" and 169.0.0.0 do not exist on your local network.
' Get all processes on a remote computer.
Dim remoteAll As Process() = Process.GetProcesses("myComputer")
' Get all instances of Notepad running on the specific computer, using machine name.
Dim remoteByName As Process() = Process.GetProcessesByName("notepad", "myComputer")
' Get all instances of Notepad running on the specific computer, using IP address.
Dim ipByName As Process() = Process.GetProcessesByName("notepad", "169.0.0.0")
' Get a process on a remote computer, using the process id and machine name.
Dim remoteById As Process = Process.GetProcessById(2345, "myComputer")
End Sub
Shared Sub Main()
Dim myProcess As New MyProcess()
myProcess.BindToRunningProcesses()
End Sub
End Class
End Namespace 'MyProcessSample
Opmerkingen
Gebruik deze methode om een matrix met nieuwe Process onderdelen te maken en deze te koppelen aan alle procesbronnen op de opgegeven (meestal externe) computer. De procesbronnen moeten al bestaan op de lokale computer, omdat GetProcesses er geen systeembronnen worden gemaakt, maar resources worden gekoppeld aan door de toepassing gegenereerde Process onderdelen. Omdat het besturingssysteem zelf achtergrondprocessen uitvoert, is deze matrix nooit leeg.
Als u niet alle processen wilt ophalen die op de computer worden uitgevoerd, kunt u het aantal beperken met behulp van de GetProcessById of GetProcessesByName methode. GetProcessById maakt een Process onderdeel dat is gekoppeld aan het proces dat op het systeem is geïdentificeerd door de proces-id die u doorgeeft aan de methode. GetProcessesByName maakt een matrix met Process onderdelen waarvan de bijbehorende procesbronnen het uitvoerbare bestand delen dat u doorgeeft aan de methode.
Deze overbelasting van de GetProcesses methode wordt over het algemeen gebruikt voor het ophalen van de lijst met procesbronnen die worden uitgevoerd op een externe computer in het netwerk, maar u kunt de lokale computer opgeven door '.' door te geven.
Note
Meerdere Windows-services kunnen worden geladen binnen hetzelfde exemplaar van het servicehostproces (svchost.exe). GetProcesses identificeert deze afzonderlijke services niet; voor dat, zie GetServices.