Informace o vnitřních členech
Krátký popis
Poskytuje informace o vnitřních členech PowerShellu, které jsou k dispozici pro všechny objekty PowerShellu.
Podrobný popis
Při vytváření objektů přidá PowerShell do každého objektu některé "skryté" vlastnosti a metody. Tyto vlastnosti a metody se označují jako vnitřní členy. Tyto vnitřní členy jsou obvykle skryté v zobrazení. Tyto skryté členy lze zobrazit pomocí parametru ForceGet-Member.
Zobrazení objektů
Vnitřní členy zahrnují sadu MemberSet vlastnosti, které představují zobrazení objektu. Podrobnější informace o vlastnostech MemberSet naleznete v tématu PSMemberSet.
Každý objekt PowerShellu obsahuje následující vlastnosti.
psbase
psbase
MemberSet obsahuje členy základního objektu bez rozšíření nebo přizpůsobení. V závislosti na typu objektu je to buď instance .NET zabalená[psobject]
instancí, nebo pokud neexistuje obálka, jedná se o samotný vstupní objekt.psadapted
psadapted
MemberSet zobrazí základní objekt plus upravené členy, pokud jsou k dispozici. Upravené členy jsou přidány Systémem rozšířeného typu (ETS).psextended
Sada
psextended
MemberSetpouze zobrazuje členy přidané soubory Types.ps1xml a rutinu Add-Member. Libovolný objekt lze za běhu rozšířit pomocí rutinyAdd-Member
.psobject
psobject
MemberSet bohatý zdroj reflexe pro libovolný objekt, který obsahuje metody, vlastnosti a další informace o objektu.
Příklady
V tomto příkladu je $hash
hashtable obsahující informace o uživateli.
Parametr síly u Get-Member
nám ukazuje vnitřní členy objektu.
$hash = @{
Age = 33
Name = 'Bob'
}
$hash | Get-Member -Force -MemberType MemberSet, CodeProperty
TypeName: System.Collections.Hashtable
Name MemberType Definition
---- ---------- ----------
pstypenames CodeProperty System.Collections.ObjectModel.Collection`1[[System.String, System.Private.CoreLib, Version=7…
psadapted MemberSet psadapted {Item, IsReadOnly, IsFixedSize, IsSynchronized, Keys, Values, SyncRoot, Count, Add,…
psbase MemberSet psbase {Item, IsReadOnly, IsFixedSize, IsSynchronized, Keys, Values, SyncRoot, Count, Add, Cl…
psextended MemberSet psextended {}
psobject MemberSet psobject {Members, Properties, Methods, ImmediateBaseObject, BaseObject, TypeNames, get_Membe…
Použití psobject
se podobá použití Get-Member
, ale poskytuje větší flexibilitu. Můžete například vytvořit výčet vlastností objektu a jejich hodnot.
$hash.psobject.Properties | Select-Object Name, MemberType, Value
Name MemberType Value
---- ---------- -----
IsReadOnly Property False
IsFixedSize Property False
IsSynchronized Property False
Keys Property {Age, Name}
Values Property {33, Bob}
SyncRoot Property {[Age, 33], [Name, Bob]}
Count Property 2
Porovnejte to s objektem vytvořeným převodem hashtable na PSCustomObject.
$user = [pscustomobject]$hash
$user.psobject.Properties | Select-Object Name, MemberType, Value
Name MemberType Value
---- ---------- -----
Age NoteProperty 33
Name NoteProperty Bob
Všimněte si, že klíče z hashtable byly převedeny na vlastnosti v PSCustomObject. Nové vlastnosti jsou nyní součástí psextended
MemberSet.
$user | Get-Member -Force -MemberType MemberSet, CodeProperty
TypeName: System.Management.Automation.PSCustomObject
Name MemberType Definition
---- ---------- ----------
pstypenames CodeProperty System.Collections.ObjectModel.Collection`1[[System.String, System.Private.CoreLib, Version=7…
psadapted MemberSet psadapted {ToString, GetType, Equals, GetHashCode}
psbase MemberSet psbase {ToString, GetType, Equals, GetHashCode}
psextended MemberSet psextended {Age, Name}
psobject MemberSet psobject {Members, Properties, Methods, ImmediateBaseObject, BaseObject, TypeNames, get_Membe…
Informace o typu
pstypenames
CodeProperty vypíše hierarchii typů objektů v pořadí dědičnosti. Například:
$file = Get-Item C:\temp\test.txt
$file.pstypenames
System.IO.FileInfo
System.IO.FileSystemInfo
System.MarshalByRefObject
System.Object
Výstup začíná nejobsáhodnějším typem objektu, System.IO.FileInfo
a pokračuje až k nejběžnějšímu typu System.Object
.
Metody
PowerShell přidá ke všem objektům PowerShellu dvě skryté metody. Tyto metody nejsou viditelné pomocí příkazu Get-Member -Force
nebo dokončování tabulátoru.
ForEach() a Where()
ForEach()
a Where()
metody jsou k dispozici pro všechny objekty PowerShellu.
Jsou ale nejužitečnější při práci s kolekcemi. Další informace o použití těchto metod naleznete v části about_Arrays.
Vlastnosti
Ne všechny skalární typy mají vlastnosti Count nebo Length v základním typu. PowerShell přidá chybějící vlastnost jako vnitřní člen pro všechny skalární typy.
Poznámka
Neinicializované proměnné jsou implicitně $null
.
$null
je skalární a má vnitřní počet a délku 0.
Zatímco vlastnosti Count a Length jsou podobné, můžou v závislosti na datovém typu fungovat jinak. Například Délka řetězce je počet znaků v řetězci. Vlastnost Count je počet instancí objektu.
PS> $str = 'string'
PS> $str.Length
6
PS> $str.Count
1
Další informace o těchto atributech naleznete v tématu about_Properties.
Skalární typy indexování polí
Pokud objekt není indexovanou kolekcí, vrátí použití operátoru indexu pro přístup k prvnímu prvku samotný objekt. Hodnoty indexu nad rámec prvního prvku vrací $null
.
PS> (2)[0]
2
PS> (2)[-1]
2
PS> (2)[1] -eq $null
True
PS> (2)[0,0] -eq $null
True
Další informace najdete v tématu about_Operators.
Metoda New() pro typy
Počínaje PowerShellem 5.0 přidá PowerShell statickou metodu New()
pro všechny typy .NET. Následující příklady vytvoří stejný výsledek.
$expression = New-Object -TypeName regex -ArgumentList 'pattern'
$expression = [regex]::new('pattern')
Použití metody new()
funguje lépe než použití New-Object
.
Další informace najdete v tématu about_Classes.