Stop-Process

停止一个或多个正在运行的进程。

语法

Stop-Process
    [-Id] <Int32[]>
    [-PassThru]
    [-Force]
    [-WhatIf]
    [-Confirm]
    [<CommonParameters>]
Stop-Process
    -Name <String[]>
    [-PassThru]
    [-Force]
    [-WhatIf]
    [-Confirm]
    [<CommonParameters>]
Stop-Process
    [-InputObject] <Process[]>
    [-PassThru]
    [-Force]
    [-WhatIf]
    [-Confirm]
    [<CommonParameters>]

说明

Stop-Process cmdlet 停止一个或多个正在运行的进程。 可以通过进程名称或进程 ID (PID) 来指定进程,也可以将进程对象传递给 Stop-ProcessStop-Process 仅对在本地计算机上运行的进程有效。

在 Windows Vista 以及 Windows 的更高版本上,若要停止不是由当前用户拥有的进程,则必须使用“以管理员身份运行”选项启动 Windows PowerShell。 此外,除非指定 Confirm 参数,否则不会提示进行确认。

示例

示例 1:停止进程的所有实例

PS C:\> Stop-Process -Name "notepad"

此命令停止计算机上 Notepad 进程的所有实例。 Notepad 的每个实例在其自己的进程中运行。 它使用 Name 参数来指定进程,所有进程都具有相同的名称。 如果要使用 Id 参数来停止相同进程,则必须列出每个 Notepad 实例的进程 ID。

示例 2:停止进程的特定实例

PS C:\> Stop-Process -Id 3952 -Confirm -PassThru

Confirm
Are you sure you want to perform this action?
Performing operation "Stop-Process" on Target "notepad (3952)".
[Y] Yes  [A] Yes to All  [N] No  [L] No to All  [S] Suspend  [?] Help
(default is "Y"):y
Handles  NPM(K)    PM(K)      WS(K) VM(M)   CPU(s)     Id ProcessName
-------  ------    -----      ----- -----   ------     -- -----------
41       2      996       3212    31            3952 notepad

此命令停止 Notepad 进程的特定实例。 它使用进程 ID 3952 来标识该进程。 Confirm 参数指示 PowerShell 在停止进程之前提示你。 由于提示中包含进程名称及其 ID,因此这是最佳实践。 PassThru 参数将该进程对象传递给格式化程序以进行显示。 如果没有此参数,则 Stop-Process 命令后不会显示。

示例 3:停止进程并检测它是否已停止

calc
$p = Get-Process -Name "calc"
Stop-Process -InputObject $p
Get-Process | Where-Object {$_.HasExited}

这一组命令启动和停止 Calc 进程,然后检测已停止的进程。

第一个命令启动一个计算器实例。

第二个命令使用 Get-Process 获取表示 Calc 进程的对象,然后将其存储在 $p 变量中。

第三个命令停止 Calc 进程。 它使用 InputObject 参数将对象传递给 Stop-Process

最后一个命令获取计算机上所有曾经运行但现已停止的进程。 它使用 Get-Process 获取计算机上的所有进程。 管道运算符 (|) 将结果传递给 Where-Object cmdlet,后者选择 HasExited 属性值为 $True 的进程。 HasExited 只是进程对象的一个属性。 若要查找所有属性,请键入 Get-Process | Get-Member

示例 4:停止当前用户不拥有的进程

PS> Get-Process -Name "lsass" | Stop-Process

Stop-Process : Cannot stop process 'lsass (596)' because of the following error: Access is denied
At line:1 char:34
+ Get-Process -Name "lsass" | Stop-Process <<<<

[ADMIN]: PS> Get-Process -Name "lsass" | Stop-Process

Warning!
Are you sure you want to perform this action?
Performing operation 'Stop-Process' on Target 'lsass(596)'
[Y] Yes  [A] Yes to All  [N] No  [L] No to All  [S] Suspend  [?] Help (default is "Y"):

[ADMIN]: PS> Get-Process -Name "lsass" | Stop-Process -Force
[ADMIN]: PS>

这些命令演示了使用 Force 停止不是由用户拥有的进程的效果。

第一个命令使用 Get-Process 来获取 Lsass 进程。 管道运算符将进程发送给 Stop-Process 以停止它。 如示例输出中所示,第一个命令失败并显示“访问被拒绝”消息,因为此进程只能由计算机上 Administrator 组的成员停止。

当使用“以管理员身份运行”选项打开 PowerShell 并重新执行该命令时,PowerShell 会提示你进行确认。

第二个命令指定 Force 以禁止显示提示。 因此进程将在不提示确认的情况下停止。

参数

-Confirm

提示你在运行 cmdlet 之前进行确认。

Type:SwitchParameter
Aliases:cf
Position:Named
Default value:False
Required:False
Accept pipeline input:False
Accept wildcard characters:False

-Force

在不提示确认的情况下停止指定的进程。 默认情况下,Stop-Process 在停止不是由当前用户拥有的任何进程之前都会提示确认。

若要查找进程的所有者,请使用 Get-CimInstance cmdlet 获取表示该进程的 Win32_Process 对象,然后使用该对象的 GetOwner 方法。

Type:SwitchParameter
Position:Named
Default value:None
Required:False
Accept pipeline input:False
Accept wildcard characters:False

-Id

指定要停止的进程的进程 ID。 若要指定多个 ID,请使用逗号分隔 ID。 若要查找进程的 PID,请键入 Get-Process

Type:Int32[]
Position:0
Default value:None
Required:True
Accept pipeline input:True
Accept wildcard characters:False

-InputObject

指定要停止的进程对象。 输入一个包含对象的变量,或键入可获取对象的命令或表达式。

Type:Process[]
Position:0
Default value:None
Required:True
Accept pipeline input:True
Accept wildcard characters:False

-Name

指定要停止的进程的进程名称。 可以键入多个进程名称(以逗号分隔)或使用通配符。

Type:String[]
Aliases:ProcessName
Position:Named
Default value:None
Required:True
Accept pipeline input:True
Accept wildcard characters:True

-PassThru

返回一个表示进程的对象。 默认情况下,此 cmdlet 将不产生任何输出。

Type:SwitchParameter
Position:Named
Default value:None
Required:False
Accept pipeline input:False
Accept wildcard characters:False

-WhatIf

显示运行该 cmdlet 时会发生什么情况。 cmdlet 未运行。

Type:SwitchParameter
Aliases:wi
Position:Named
Default value:False
Required:False
Accept pipeline input:False
Accept wildcard characters:False

输入

Process

可以将进程对象通过管道传递给此 cmdlet。

输出

None

默认情况下,此 cmdlet 不返回任何输出。

Process

使用 PassThru 参数时,此 cmdlet 返回表示已停止进程的 Process 对象

备注

PowerShell 包含 Stop-Process 的以下别名:

  • 所有平台:
    • spps
  • Windows:
    • kill

你也可以使用 Windows PowerShell 中的 Windows Management Instrumentation (WMI) Win32_Process 对象的属性和方法。 有关详细信息,请参阅 Get-CimInstance 和 WMI SDK。

  • 停止进程时,应意识到,停止进程可能会停止进程和依赖该进程的服务。 在极端情况下,停止进程可能会使 Windows 停止。