Dela via


Använd statiska klasser och metoder

Det går inte att skapa alla .NET Framework-klasser med .New-Object Om du till exempel försöker skapa ett System.Environment- eller System.Math-objekt med New-Objectfå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

Dessa fel uppstår eftersom det inte finns något sätt 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

Det första steget i att arbeta med ett objekt i Windows PowerShell är vanligtvis att använda Get-Member för att 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

Kommentar

Som vi nämnde tidigare förbereder Windows PowerShell automatiskt "System". för att skriva namn när du använder New-Object. Samma sak händer när du använder ett typnamn med hakparentes, så 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 i Windows PowerShell.

Om du försöker visa information om den här klassen genom att skriva [System.Environment] | Get-Member, objekttypen rapporteras vara System.RuntimeType , inte System.Environment:

[System.Environment] | Get-Member
   TypeName: System.RuntimeType

Om du vill visa statiska medlemmar med Get-Member anger du den statiska parametern:

[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 som ska visas 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 ange för Windows PowerShell att vi vill arbeta med en statisk metod eller egenskap. Om du vill 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 osVersion-egenskapen 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 åtgärder. Klassen innehåller flera användbara metoder som vi kan visa med hjälp av Get-Member.

Kommentar

System.Math har flera metoder med samma namn, men de särskiljs av typen av parametrar.

Skriv följande kommando för att visa metoderna för 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