Pop-Location
Změní aktuální umístění na umístění naposledy vložené do zásobníku.
Syntaxe
Pop-Location
[-PassThru]
[-StackName <String>]
[-UseTransaction]
[<CommonParameters>]
Description
Rutina Pop-Location
změní aktuální umístění na umístění naposledy vložené do zásobníku pomocí rutiny Push-Location
. Umístění můžete zobrazit z výchozího zásobníku nebo ze zásobníku, který vytvoříte pomocí Push-Location
příkazu.
Příklady
Příklad 1: Změna na nejnovější umístění
PS C:\> Pop-Location
Tento příkaz změní umístění na umístění, které bylo naposledy přidáno do aktuálního zásobníku.
Příklad 2: Změna na nejnovější umístění v pojmenovaném zásobníku
PS C:\> Pop-Location -StackName "Stack2"
Tento příkaz změní umístění na umístění, které bylo naposledy přidáno do zásobníku umístění Stack2.
Další informace o zásobníkech umístění najdete v poznámkách.
Příklad 3: Přechod mezi umístěními pro různé poskytovatele
PS C:\> pushd HKLM:\Software\Microsoft\PowerShell
PS HKLM:\Software\Microsoft\PowerShell> pushd Cert:\LocalMachine\TrustedPublisher
PS cert:\LocalMachine\TrustedPublisher> popd
PS HKLM:\Software\Microsoft\PowerShell> popd
PS C:\>
Tyto příkazy používají Push-Location
rutiny Pop-Location
k pohybu mezi umístěními podporovanými různými poskytovateli PowerShellu. Příkazy používají pushd
alias pro Push-Location
a popd
alias pro Pop-Location
.
První příkaz odešle aktuální umístění systému souborů do zásobníku a přesune se na jednotku HKLM podporovanou poskytovatelem registru PowerShellu.
Druhý příkaz nasdílí umístění registru do zásobníku a přesune se do umístění podporovaného poskytovatelem certifikátu PowerShellu.
Poslední dva příkazy zobrazí tato umístění mimo zásobník. První popd
příkaz se vrátí na jednotku Registru a druhý příkaz se vrátí na jednotku systému souborů.
Parametry
-PassThru
Předá objekt, který představuje umístění kanálu. Ve výchozím nastavení tato rutina negeneruje žádný výstup.
Typ: | SwitchParameter |
Position: | Named |
Default value: | None |
Vyžadováno: | False |
Přijmout vstup kanálu: | False |
Přijmout zástupné znaky: | False |
-StackName
Určuje zásobník umístění, ze kterého se umístění přepnulo. Zadejte název zásobníku umístění.
Bez tohoto parametru Pop-Location
se zobrazí umístění z aktuálního zásobníku umístění. Ve výchozím nastavení je aktuální zásobník umístění nepojmenovaný výchozí zásobník umístění, který PowerShell vytvoří. Pokud chcete vytvořit zásobník umístění jako aktuální zásobník umístění, použijte parametr StackName rutiny Set-Location
. Další informace o zásobníkech umístění najdete v poznámkách.
Pop-Location
Aplikace nemůže otevřít umístění z nepojmenovaného výchozího zásobníku, pokud se nejedná o aktuální zásobník umístění.
Typ: | String |
Position: | Named |
Default value: | None |
Vyžadováno: | False |
Přijmout vstup kanálu: | True |
Přijmout zástupné znaky: | False |
-UseTransaction
Zahrnuje příkaz v aktivní transakci. Tento parametr je platný pouze v případě, že probíhá transakce. Další informace najdete v tématu about_Transactions.
Typ: | SwitchParameter |
Aliasy: | usetx |
Position: | Named |
Default value: | False |
Vyžadováno: | False |
Přijmout vstup kanálu: | False |
Přijmout zástupné znaky: | False |
Vstupy
None
Do této rutiny nemůžete roušit objekty.
Výstupy
None
Ve výchozím nastavení tato rutina nevrací žádný výstup.
Pokud použijete parametr PassThru , vrátí tato rutina objekt PathInfo představující aktuální cestu po operaci rutiny.
Poznámky
Windows PowerShell obsahuje následující aliasy pro Pop-Location
:
popd
PowerShell podporuje více prostředí runspace na proces. Každý runspace má svůj vlastní aktuální adresář.
To není totéž jako [System.Environment]::CurrentDirectory
. Toto chování může být problém při volání rozhraní .NET API nebo spouštění nativních aplikací bez poskytování explicitních cest k adresářům.
I když rutiny umístění nastavily aktuální adresář pro celý proces, nemůžete na něm záviset, protože ho může kdykoli změnit jiný runspace. Rutiny umístění byste měli použít k provádění operací založených na cestě pomocí aktuálního pracovního adresáře specifického pro aktuální prostředí Runspace.
Zásobník je poslední první seznam, ve kterém lze získat přístup pouze k naposledy přidané položce. Položky přidáte do zásobníku v pořadí, v jakém je používáte, a pak je načtete pro použití v obráceném pořadí. PowerShell umožňuje ukládat umístění zprostředkovatelů do zásobníků umístění.
PowerShell vytvoří nepojmenovaný výchozí zásobník umístění a můžete vytvořit několik pojmenovaných zásobníků umístění. Pokud nezadáte název zásobníku, PowerShell použije aktuální zásobník umístění. Ve výchozím nastavení je nepojmenované výchozí umístění aktuální zásobník umístění, ale pomocí rutiny Set-Location
můžete změnit aktuální zásobník umístění.
Ke správě zásobníků umístění použijte rutiny PowerShellu *-Location
následujícím způsobem:
Pokud chcete přidat umístění do zásobníku umístění, použijte tuto rutinu
Push-Location
.Pokud chcete získat umístění ze zásobníku umístění, použijte rutinu
Pop-Location
.Pokud chcete zobrazit umístění v aktuálním zásobníku umístění, použijte parametr Stack rutiny
Get-Location
.Pokud chcete zobrazit umístění v pojmenovaném zásobníku umístění, použijte parametr StackName rutiny
Get-Location
.K vytvoření nového zásobníku umístění použijte parametr StackName rutiny
Push-Location
. Pokud zadáte zásobník, který neexistuje,Push-Location
vytvoří se zásobník.Pokud chcete vytvořit zásobník umístění jako aktuální zásobník umístění, použijte parametr StackName rutiny
Set-Location
.
Výchozí zásobník nenaznačeného umístění je plně přístupný jenom v případech, kdy se jedná o aktuální zásobník umístění.
Pokud nastavíte pojmenovaný zásobník umístění jako aktuální zásobník umístění, nebudete už moct přidávat Push-Location
Pop-Location
nebo získávat položky z výchozího zásobníku nebo pomocí Get-Location
rutiny zobrazovat umístění v nepojmenovaném zásobníku. Pokud chcete, aby byl zásobník bez názvu aktuální, použijte parametr StackName rutiny s hodnotou $Null
nebo prázdným řetězcem (""
Set-Location
).
Pop-Location
je navržený tak, aby fungoval s daty vystavenými jakýmkoli poskytovatelem. Pokud chcete zobrazit seznam poskytovatelů dostupných v relaci, zadejte Get-PSProvider
. Další informace najdete v tématu about_Providers.