Używanie metod i klas statycznych
Nie wszystkie klasy programu .NET Framework można utworzyć przy użyciu polecenia New-Object
. Jeśli na przykład spróbujesz utworzyć obiekt System.Environment lub System.Math za pomocą New-Object
polecenia , zostaną wyświetlone następujące komunikaty o błędach:
New-Object System.Environment
New-Object : Constructor not found. Cannot find an appropriate constructor for
type System.Environment.
At line:1 char:11
+ New-Object <<<< System.Environment
New-Object System.Math
New-Object : Constructor not found. Cannot find an appropriate constructor for
type System.Math.
At line:1 char:11
+ New-Object <<<< System.Math
Te błędy występują, ponieważ nie ma możliwości utworzenia nowego obiektu na podstawie tych klas. Te klasy to biblioteki referencyjne metod i właściwości, które nie zmieniają stanu. Nie musisz ich tworzyć, wystarczy ich użyć. Klasy i metody, takie jak te, są nazywane klasami statycznymi, ponieważ nie są tworzone, niszczone ani zmieniane. Aby to wyjaśnić, przedstawimy przykłady, które używają klas statycznych.
Pobieranie danych środowiska za pomocą pliku System.Environment
Zazwyczaj pierwszym krokiem pracy z obiektem w programie Windows PowerShell jest użycie polecenia Get-Member w celu ustalenia, jakie elementy członkowskie zawiera. W przypadku klas statycznych proces jest nieco inny, ponieważ rzeczywista klasa nie jest obiektem.
Odwołanie do statycznej klasy System.Environment
Możesz odwołać się do klasy statycznej, otaczając nazwę klasy nawiasami kwadratowymi. Na przykład możesz odwołać się do pliku System.Environment , wpisując nazwę w nawiasach kwadratowych. Spowoduje to wyświetlenie pewnych ogólnych informacji o typie:
[System.Environment]
IsPublic IsSerial Name BaseType
-------- -------- ---- --------
True False Environment System.Object
Uwaga
Jak wspomniano wcześniej, program Windows PowerShell automatycznie poprzedza "System". do wpisywania nazw podczas używania polecenia New-Object
. Dzieje się tak samo w przypadku używania nazwy typu w nawiasie, więc można określić [System.Environment] jako [Środowisko].
Klasa System.Environment zawiera ogólne informacje o środowisku roboczym dla bieżącego procesu, który jest powershell.exe
podczas pracy w programie Windows PowerShell.
Jeśli spróbujesz wyświetlić szczegóły tej klasy, wpisując [System.Environment] | Get-Member, typ obiektu jest zgłaszany jako System.RuntimeType , a nie System.Environment:
[System.Environment] | Get-Member
TypeName: System.RuntimeType
Aby wyświetlić statyczne elementy członkowskie za pomocą polecenia Get-Member, określ parametr statyczny:
[System.Environment] | Get-Member -Static
TypeName: System.Environment
Name MemberType Definition
---- ---------- ----------
Equals Method static System.Boolean Equals(Object ob...
Exit Method static System.Void Exit(Int32 exitCode)
...
CommandLine Property static System.String CommandLine {get;}
CurrentDirectory Property static System.String CurrentDirectory ...
ExitCode Property static System.Int32 ExitCode {get;set;}
HasShutdownStarted Property static System.Boolean HasShutdownStart...
MachineName Property static System.String MachineName {get;}
NewLine Property static System.String NewLine {get;}
OSVersion Property static System.OperatingSystem OSVersio...
ProcessorCount Property static System.Int32 ProcessorCount {get;}
StackTrace Property static System.String StackTrace {get;}
SystemDirectory Property static System.String SystemDirectory {...
TickCount Property static System.Int32 TickCount {get;}
UserDomainName Property static System.String UserDomainName {g...
UserInteractive Property static System.Boolean UserInteractive ...
UserName Property static System.String UserName {get;}
Version Property static System.Version Version {get;}
WorkingSet Property static System.Int64 WorkingSet {get;}
TickCount ExitCode
Teraz możemy wybrać właściwości do wyświetlenia w pliku System.Environment.
Wyświetlanie właściwości statycznych środowiska System.Environment
Właściwości pliku System.Environment są również statyczne i muszą być określone w inny sposób niż właściwości normalne. Używamy ::
polecenia , aby wskazać programOwi Windows PowerShell, że chcemy pracować z metodą statyczną lub właściwością. Aby wyświetlić polecenie użyte do uruchomienia programu Windows PowerShell, sprawdzamy właściwość CommandLine , wpisując polecenie:
[System.Environment]::Commandline
"C:\Program Files\Windows PowerShell\v1.0\powershell.exe"
Aby sprawdzić wersję systemu operacyjnego, wyświetl właściwość OSVersion, wpisując:
[System.Environment]::OSVersion
Platform ServicePack Version VersionString
-------- ----------- ------- -------------
Win32NT Service Pack 2 5.1.2600.131072 Microsoft Windows...
Możemy sprawdzić, czy komputer jest w trakcie zamykania, wyświetlając właściwość HasShutdownStarted :
[System.Environment]::HasShutdownStarted
False
Wykonywanie matematyki za pomocą biblioteki System.Math
Klasa statyczna System.Math jest przydatna do wykonywania niektórych operacji matematycznych. Klasa zawiera kilka przydatnych metod, które możemy wyświetlić przy użyciu polecenia Get-Member
.
Uwaga
System.Math ma kilka metod o tej samej nazwie, ale są one rozróżniane przez typ ich parametrów.
Wpisz następujące polecenie, aby wyświetlić listę metod klasy System.Math .
[System.Math] | Get-Member -Static -MemberType Methods
TypeName: System.Math
Name MemberType Definition
---- ---------- ----------
Abs Method static System.Single Abs(Single value), static Sy...
Acos Method static System.Double Acos(Double d)
Asin Method static System.Double Asin(Double d)
Atan Method static System.Double Atan(Double d)
Atan2 Method static System.Double Atan2(Double y, Double x)
BigMul Method static System.Int64 BigMul(Int32 a, Int32 b)
Ceiling Method static System.Double Ceiling(Double a), static Sy...
Cos Method static System.Double Cos(Double d)
Cosh Method static System.Double Cosh(Double value)
DivRem Method static System.Int32 DivRem(Int32 a, Int32 b, Int3...
Equals Method static System.Boolean Equals(Object objA, Object ...
Exp Method static System.Double Exp(Double d)
Floor Method static System.Double Floor(Double d), static Syst...
IEEERemainder Method static System.Double IEEERemainder(Double x, Doub...
Log Method static System.Double Log(Double d), static System...
Log10 Method static System.Double Log10(Double d)
Max Method static System.SByte Max(SByte val1, SByte val2), ...
Min Method static System.SByte Min(SByte val1, SByte val2), ...
Pow Method static System.Double Pow(Double x, Double y)
ReferenceEquals Method static System.Boolean ReferenceEquals(Object objA...
Round Method static System.Double Round(Double a), static Syst...
Sign Method static System.Int32 Sign(SByte value), static Sys...
Sin Method static System.Double Sin(Double a)
Sinh Method static System.Double Sinh(Double value)
Sqrt Method static System.Double Sqrt(Double d)
Tan Method static System.Double Tan(Double a)
Tanh Method static System.Double Tanh(Double value)
Truncate Method static System.Decimal Truncate(Decimal d), static...
Spowoduje to wyświetlenie kilku metod matematycznych. Oto lista poleceń, które pokazują, jak działają niektóre typowe metody:
[System.Math]::Sqrt(9)
3
[System.Math]::Pow(2,3)
8
[System.Math]::Floor(3.3)
3
[System.Math]::Floor(-3.3)
-4
[System.Math]::Ceiling(3.3)
4
[System.Math]::Ceiling(-3.3)
-3
[System.Math]::Max(2,7)
7
[System.Math]::Min(2,7)
2
[System.Math]::Truncate(9.3)
9
[System.Math]::Truncate(-9.3)
-9