Använd statiska klasser och metoder
Det går inte .NET Framework alla klasser kan skapas med hjälp av New-Object . Om du till exempel försöker skapa en System.Environment eller ett System.Math-objekt med New-Object får du följande felmeddelanden:
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
De här felen uppstår eftersom det inte går att skapa ett nytt objekt från dessa klasser. Dessa klasser är referensbibliotek med metoder och egenskaper som inte ändrar tillstånd. Du behöver inte skapa dem, du använder dem bara. Klasser och metoder som dessa kallas statiska klasser eftersom de inte skapas, förstörs eller ändras. För att göra detta tydligt tillhandahåller vi exempel som använder statiska klasser.
Hämta miljödata med System.Environment
Vanligtvis är det första steget i att arbeta med ett objekt i Windows PowerShell att använda Get-Member ta reda på vilka medlemmar det innehåller. Med statiska klasser är processen lite annorlunda eftersom den faktiska klassen inte är ett objekt.
Referera till klassen Static System.Environment
Du kan referera till en statisk klass genom att omge klassnamnet med hakparenteser. Du kan till exempel referera till System.Environment genom att skriva namnet inom hakparenteser. Om du gör det visas viss allmän typinformation:
[System.Environment]
IsPublic IsSerial Name BaseType
-------- -------- ---- --------
True False Environment System.Object
Anteckning
Som vi nämnde tidigare Windows PowerShell automatiskt förberedelse av "System"." för att skriva namn när du använder New-Object . Samma sak händer när du använder ett namn med hakparenteser, så att du kan ange [ System.Environment] som [ Miljö].
Klassen System.Environment innehåller allmän information om arbetsmiljön för den aktuella processen, vilket är powershell.exe när du arbetar Windows PowerShell.
Om du försöker visa information om den här klassen genom att skriva [ System.Environment] | Get-Member, objekttypen rapporteras som System.RuntimeType , inte System.Environment:
[System.Environment] | Get-Member
TypeName: System.RuntimeType
Om du vill visa statiska medlemmar med Get-Member anger du parametern Static:
[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
Nu kan vi välja egenskaper att visa från System.Environment.
Visa statiska egenskaper för System.Environment
Egenskaperna för System.Environment är också statiska och måste anges på ett annat sätt än normala egenskaper. Vi använder :: för att Windows PowerShell att vi vill arbeta med en statisk metod eller egenskap. För att se kommandot som användes för att starta Windows PowerShell kontrollerar vi egenskapen CommandLine genom att skriva:
[System.Environment]::Commandline
"C:\Program Files\Windows PowerShell\v1.0\powershell.exe"
Om du vill kontrollera operativsystemversionen visar du egenskapen OSVersion genom att skriva:
[System.Environment]::OSVersion
Platform ServicePack Version VersionString
-------- ----------- ------- -------------
Win32NT Service Pack 2 5.1.2600.131072 Microsoft Windows...
Vi kan kontrollera om datorn håller på att stängas av genom att visa egenskapen HasShutdownStarted:
[System.Environment]::HasShutdownStarted
False
Göra matematik med System.Math
Den statiska klassen System.Math är användbar för att utföra vissa matematiska operationer. De viktiga medlemmarna i System.Math är huvudsakligen metoder, som vi kan visa med hjälp av Get-Member .
Anteckning
System.Math har flera metoder med samma namn, men de särskiljs av typen av parametrar.
Skriv följande kommando för att visa en lista över metoderna i klassen 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...
Detta visar flera matematiska metoder. Här är en lista över kommandon som visar hur några av de vanliga metoderna fungerar:
[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