Einige .NET Framework-Klassen können nicht mit New-Object erstellt werden. Wenn Sie z. B. versuchen, ein System.Environment-Objekt oder ein System.Math-Objekt mit New-Object zu erstellen, erhalten Sie die folgenden Fehlermeldungen:

PS> 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
PS> 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

Die Ursache für diesen Fehler besteht darin, dass aus diesen Klassen keine neuen Objekte erstellt werden können. Bei diesen Klassen handelt es sich um Referenzbibliotheken für Methoden und Eigenschaften, deren Status unveränderlich ist. Sie müssen nicht erstellt, sondern können einfach verwendet werden. Solche Klassen und Methoden werden als statische Klassen bezeichnet, da sie nicht erstellt, zerstört oder geändert werden können. Einige Beispiele mit statischen Klassen sollen dies veranschaulichen.

Abrufen von Umgebungsdaten mit "System.Environment"

Wenn Sie ein Objekt in Windows PowerShell verwenden, wird zunächst meist der Inhalt der Elemente mit dem Cmdlet "Get-Member" bestimmt. Die Vorgehensweise bei statischen Klassen weicht etwas ab, da die eigentliche Klasse kein Objekt darstellt.

Verweisen auf die statische System.Environment-Klasse

Sie können auf eine statische Klasse verweisen, indem Sie den Klassennamen in eckige Klammern einschließen. Sie können beispielsweise die System.Environment-Klasse in Klammern einschließen, um auf diese zu verweisen. Dadurch werden einige generische Typinformationen angezeigt:

PS> [System.Environment]

IsPublic IsSerial Name                                     BaseType
-------- -------- ----                                     --------
True     False    Environment                              System.Object
Hinweis:

Wie bereits erwähnt, stellt Windows PowerShell Typnamen bei Verwendung von New-Object automatisch System. voran. Dies ist auch bei Verwendung eines Typnamens in eckigen Klammern der Fall, daher können Sie [Environment] statt [System.Environment] angeben.

In Windows PowerShell enthält die System.Environment-Klasse allgemeine Informationen zur Arbeitsumgebung für den aktuellen Prozess "powershell.exe".

Wenn Sie versuchen, Details dieser Klasse anzuzeigen, indem Sie [System.Environment] | Get-Member eingeben, wird als Objekttyp System.RuntimeType gemeldet, nicht System.Environment:

PS> [System.Environment] | Get-Member

   TypeName: System.RuntimeType

Wenn Sie statische Elemente mit Get-Member anzeigen möchten, geben Sie den Static -Parameter an:

PS> [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

Nun können Eigenschaften zur Anzeige von "System.Environment" ausgewählt werden.

Anzeigen von statischen Eigenschaften von "System.Environment"

Auch die Eigenschaften von "System.Environment" sind statisch und müssen anders als normale Eigenschaften angegeben werden. In Windows PowerShell wird die Verwendung einer statischen Methode oder Eigenschaft durch :: angegeben. Zum Anzeigen des zum Starten von Windows PowerShell verwendeten Befehls überprüfen Sie die CommandLine-Eigenschaft durch folgende Eingabe:

PS> [System.Environment]::Commandline
"C:\Program Files\Windows PowerShell\v1.0\powershell.exe"

Die Betriebssystemversion kann durch Anzeigen der OSVersion-Eigenschaft mit folgender Eingabe angezeigt werden:

PS> [System.Environment]::OSVersion

           Platform ServicePack         Version             VersionString
           -------- -----------         -------             -------------
            Win32NT Service Pack 2      5.1.2600.131072     Microsoft Window...

Um festzustellen, ob der Computer gerade heruntergefahren wird, kann die HasShutdownStarted -Eigenschaft angezeigt werden:

PS> [System.Environment]::HasShutdownStarted
False  

Durchführen von Berechnungen mit "System.Math"

Die statische System.Math-Klasse eignet sich für einige mathematische Berechnungen. Bei den wichtigen Elementen von System.Math handelt es sich meist um Methoden, die mit Get-Member angezeigt werden können.

Hinweis:

"System.Math" enthält mehrere Methoden mit gleichem Namen, die jedoch anhand des Parametertyps unterschieden werden können.

Geben Sie den folgenden Befehl ein, um die Methoden der System.Math-Klasse aufzulisten.

PS> [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...

Dadurch werden mehrere mathematische Methoden angezeigt. Nachfolgend finden Sie eine Liste der Befehle, die die Funktion einiger häufig verwendeter Methoden veranschaulichen:

PS> [System.Math]::Sqrt(9)
3
PS> [System.Math]::Pow(2,3)
8
PS> [System.Math]::Floor(3.3)
3
PS> [System.Math]::Floor(-3.3)
-4
PS> [System.Math]::Ceiling(3.3)
4
PS> [System.Math]::Ceiling(-3.3)
-3
PS> [System.Math]::Max(2,7)
7
PS> [System.Math]::Min(2,7)
2
PS> [System.Math]::Truncate(9.3)
9
PS> [System.Math]::Truncate(-9.3)
-9




Inhaltsverzeichnis