Process.GetProcessById Método
Definición
Importante
Parte de la información hace referencia a la versión preliminar del producto, que puede haberse modificado sustancialmente antes de lanzar la versión definitiva. Microsoft no otorga ninguna garantía, explícita o implícita, con respecto a la información proporcionada aquí.
Crea un nuevo componente Process y lo asocia al recurso de proceso existente que se especifique.
Sobrecargas
GetProcessById(Int32) |
Devuelve un nuevo componente Process, dado un identificador de un proceso en el equipo local. |
GetProcessById(Int32, String) |
Devuelve un nuevo componente Process, dados un identificador de proceso y el nombre de un equipo en la red. |
GetProcessById(Int32)
- Source:
- Process.cs
- Source:
- Process.cs
- Source:
- Process.cs
Devuelve un nuevo componente Process, dado un identificador de un proceso en el equipo local.
public:
static System::Diagnostics::Process ^ GetProcessById(int processId);
public static System.Diagnostics.Process GetProcessById (int processId);
static member GetProcessById : int -> System.Diagnostics.Process
Public Shared Function GetProcessById (processId As Integer) As Process
Parámetros
- processId
- Int32
Identificador de un recurso de proceso único en el sistema.
Devoluciones
Componente Process asociado al recurso del proceso local que se identifica mediante el parámetro processId
.
Excepciones
El proceso especificado por el parámetro processId
no se está ejecutando. Es posible que el identificador haya expirado.
Ejemplos
En el ejemplo siguiente se recupera información del proceso actual, los procesos que se ejecutan en el equipo local, todas las instancias del Bloc de notas que se ejecutan en el equipo local y un proceso específico en el equipo local. A continuación, recupera información para los mismos procesos en un equipo remoto.
#using <System.dll>
using namespace System;
using namespace System::Diagnostics;
using namespace System::ComponentModel;
int main()
{
// Get the current process.
Process^ currentProcess = Process::GetCurrentProcess();
// Get all processes running on the local computer.
array<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.
array<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.
array<Process^>^remoteAll = Process::GetProcesses("myComputer");
// Get all instances of Notepad running on the specific computer, using machine name.
array<Process^>^remoteByName = Process::GetProcessesByName( "notepad", "myComputer" );
// Get all instances of Notepad running on the specific computer, using IP address.
array<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" );
}
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();
}
}
}
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
Comentarios
Use este método para crear un nuevo Process componente y asociarlo a un recurso de proceso en el equipo local. El recurso de proceso ya debe existir en el equipo, ya que GetProcessById(Int32) no crea un recurso del sistema, sino que asocia un recurso a un componente generado por Process la aplicación. Un proceso Id solo se puede recuperar para un proceso que se está ejecutando actualmente en el equipo. Una vez finalizado el proceso, GetProcessById(Int32) se produce una excepción si se pasa un identificador expirado.
En cualquier equipo determinado, el identificador de un proceso es único. GetProcessById(Int32) devuelve un proceso como máximo. Si desea obtener todos los procesos que ejecutan una aplicación determinada, use GetProcessesByName(String). Si existen varios procesos en el equipo que ejecuta la aplicación especificada, GetProcessesByName(String) devuelve una matriz que contiene todos los procesos asociados. Puede consultar cada uno de estos procesos a su vez para su identificador. El identificador de proceso se puede ver en el Processes
panel del Administrador de tareas de Windows. La PID
columna muestra el identificador de proceso asignado a un proceso.
El processId
parámetro es un (entero Int32 de 32 bits con signo), aunque la API subyacente de Windows usa un DWORD
(entero de 32 bits sin signo) para API similares. Esto es por razones históricas.
Consulte también
Se aplica a
GetProcessById(Int32, String)
- Source:
- Process.cs
- Source:
- Process.cs
- Source:
- Process.cs
Devuelve un nuevo componente Process, dados un identificador de proceso y el nombre de un equipo en la red.
public:
static System::Diagnostics::Process ^ GetProcessById(int processId, System::String ^ machineName);
public static System.Diagnostics.Process GetProcessById (int processId, string machineName);
static member GetProcessById : int * string -> System.Diagnostics.Process
Public Shared Function GetProcessById (processId As Integer, machineName As String) As Process
Parámetros
- processId
- Int32
Identificador de un recurso de proceso único en el sistema.
- machineName
- String
Nombre de un equipo en la red.
Devoluciones
Componente Process asociado a un recurso de proceso remoto que se identifica mediante el parámetro processId
.
Excepciones
El proceso especificado por el parámetro processId
no se está ejecutando. Es posible que el identificador haya expirado.
o bien
La sintaxis de parámetro machineName
no es válida. El nombre puede tener longitud cero (0).
El parámetro machineName
es null
.
Ejemplos
En el ejemplo siguiente se recupera información del proceso actual, los procesos que se ejecutan en el equipo local, todas las instancias del Bloc de notas que se ejecutan en el equipo local y un proceso específico en el equipo local. A continuación, recupera información para los mismos procesos en un equipo remoto.
#using <System.dll>
using namespace System;
using namespace System::Diagnostics;
using namespace System::ComponentModel;
int main()
{
// Get the current process.
Process^ currentProcess = Process::GetCurrentProcess();
// Get all processes running on the local computer.
array<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.
array<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.
array<Process^>^remoteAll = Process::GetProcesses("myComputer");
// Get all instances of Notepad running on the specific computer, using machine name.
array<Process^>^remoteByName = Process::GetProcessesByName( "notepad", "myComputer" );
// Get all instances of Notepad running on the specific computer, using IP address.
array<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" );
}
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();
}
}
}
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
Comentarios
Use este método para crear un nuevo Process componente y asociarlo a un recurso de proceso en un equipo remoto de la red. El recurso de proceso ya debe existir en el equipo especificado, ya que GetProcessById(Int32, String) no crea un recurso del sistema, sino que asocia un recurso a un componente generado por Process la aplicación. Un proceso Id solo se puede recuperar para un proceso que se está ejecutando actualmente en el equipo. Una vez finalizado el proceso, GetProcessById(Int32, String) se produce una excepción si se pasa un identificador expirado.
En cualquier equipo determinado, el identificador de un proceso es único. GetProcessById(Int32, String) devuelve un proceso como máximo. Si desea obtener todos los procesos que ejecutan una aplicación determinada, use GetProcessesByName(String). Si existen varios procesos en el equipo que ejecuta la aplicación especificada, GetProcessesByName(String) devuelve una matriz que contiene todos los procesos asociados. Puede consultar cada uno de estos procesos a su vez para su identificador. El identificador de proceso se puede ver en el Processes
panel del Administrador de tareas de Windows. La PID
columna muestra el identificador de proceso asignado a un proceso.
Si no especifica un machineName
, se usa el equipo local. Como alternativa, puede especificar el equipo local estableciendo machineName
en el valor "." o en una cadena vacía ("").
El processId
parámetro es un (entero Int32 de 32 bits con signo), aunque la API subyacente de Windows usa un DWORD
(entero de 32 bits sin signo) para API similares. Esto es por razones históricas.