Partilhar via


Get-PSCallStack

Exibe a pilha de chamadas atual.

Sintaxe

Get-PSCallStack []

Description

O Get-PSCallStack cmdlet exibe a pilha de chamadas atual.

Embora tenha sido projetado para ser usado com o depurador do Windows PowerShell, você pode usar esse cmdlet para exibir a pilha de chamadas em um script ou função fora do depurador.

Para executar um Get-PSCallStack comando enquanto estiver no depurador, digite k ou Get-PSCallStack.

Exemplos

Exemplo 1: Obter a pilha de chamadas para uma função

PS C:\> function my-alias {
$p = $args[0]
Get-Alias | where {$_.definition -like "*$p"} | format-table definition, name -auto
}
PS C:\ps-test> Set-PSBreakpoint -Command my-alias
Command    : my-alias
Action     :
Enabled    : True
HitCount   : 0
Id         : 0
Script     : prompt PS C:\> my-alias Get-Content

Entering debug mode. Use h or ? for help.
Hit Command breakpoint on 'prompt:my-alias'
my-alias get-content
[DBG]: PS C:\ps-test> s
$p = $args[0]
DEBUG: Stepped to ':    $p = $args[0]    '
[DBG]: PS C:\ps-test> s
get-alias | Where {$_.Definition -like "*$p*"} | format-table Definition,
[DBG]: PS C:\ps-test>get-pscallstack

Name        CommandLineParameters         UnboundArguments              Location
----        ---------------------         ----------------              --------
prompt      {}                            {}                            prompt
my-alias    {}                            {get-content}                 prompt
prompt      {}                            {}                            prompt

PS C:\> [DBG]: PS C:\ps-test> o
Definition  Name
----------  ----
Get-Content gc
Get-Content cat
Get-Content type

Este comando usa o Get-PSCallStack cmdlet para exibir a pilha de chamadas para My-Alias, uma função simples que obtém os aliases para um nome de cmdlet.

O primeiro comando entra na função no prompt do Windows PowerShell. O segundo comando usa o Set-PSBreakpoint cmdlet para definir um ponto de interrupção na My-Alias função. O terceiro comando usa a My-Alias função para obter todos os aliases na sessão atual para o Get-Content cmdlet.

O depurador entra na chamada de função. Dois comandos consecutivos step-into (s) começam a executar a função linha por linha. Em seguida, um Get-PSCallStack comando é usado para recuperar a pilha de chamadas.

O comando final é um Step-Out comando (o) que sai do depurador e continua executando o script até a conclusão.

Entradas

None

Não é possível canalizar objetos para este cmdlet.

Saídas

CallStackFrame

Este cmdlet retorna um objeto que representa os itens na pilha de chamadas.

Notas

O PowerShell inclui os seguintes aliases para Get-PSCallStack:

  • Todas as plataformas:
    • gcs