Sdílet prostřednictvím


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 psextendedMemberSetpouze zobrazuje členy přidané soubory Types.ps1xml a rutinu Add-Member. Libovolný objekt lze za běhu rozšířit pomocí rutiny Add-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í psextendedMemberSet.

$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.FileInfoa 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.