Statische klassen en methoden gebruiken
Niet alle .NET Framework-klassen kunnen worden gemaakt met behulp van New-Object
. Als u bijvoorbeeld een System.Environment - of System.Math-object probeert te maken, New-Object
krijgt u de volgende foutberichten:
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
Deze fouten treden op omdat er geen manier is om een nieuw object te maken op basis van deze klassen. Deze klassen zijn referentiebibliotheken met methoden en eigenschappen die de status niet wijzigen. U hoeft ze niet te maken, u gebruikt ze gewoon. Klassen en methoden zoals deze worden statische klassen genoemd omdat ze niet worden gemaakt, vernietigd of gewijzigd. Om dit duidelijk te maken, geven we voorbeelden die statische klassen gebruiken.
Omgevingsgegevens ophalen met System.Environment
Meestal is de eerste stap bij het werken met een object in Windows PowerShell het gebruik van Get-Member om erachter te komen welke leden het bevat. Bij statische klassen is het proces iets anders omdat de werkelijke klasse geen object is.
Verwijzen naar de klasse static System.Environment
U kunt verwijzen naar een statische klasse door de naam van de klasse te omringen met vierkante haken. U kunt bijvoorbeeld verwijzen naar System.Environment door de naam tussen vierkante haken te typen. Als u dit doet, worden enkele algemene typegegevens weergegeven:
[System.Environment]
IsPublic IsSerial Name BaseType
-------- -------- ---- --------
True False Environment System.Object
Notitie
Zoals we eerder hebben vermeld, wordt 'Systeem' automatisch voorafgegaan door Windows PowerShell. om namen te typen wanneer u gebruikt New-Object
. Hetzelfde gebeurt wanneer u een naam met een haakje gebruikt, zodat u [System.Environment] kunt opgeven als [Omgeving].
De klasse System.Environment bevat algemene informatie over de werkomgeving voor het huidige proces. Dit is powershell.exe
wanneer u in Windows PowerShell werkt.
Als u de details van deze klasse probeert weer te geven door [System.Environment] | Get-Member, het objecttype wordt gerapporteerd als System.RuntimeType , niet System.Environment:
[System.Environment] | Get-Member
TypeName: System.RuntimeType
Als u statische leden wilt weergeven met Get-Member, geeft u de statische parameter op:
[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
We kunnen nu eigenschappen selecteren om weer te geven vanuit System.Environment.
Statische eigenschappen van System.Environment weergeven
De eigenschappen van System.Environment zijn ook statisch en moeten op een andere manier worden opgegeven dan normale eigenschappen. We gebruiken ::
om aan te geven aan Windows PowerShell dat we willen werken met een statische methode of eigenschap. Als u de opdracht wilt zien die is gebruikt om Windows PowerShell te starten, controleren we de eigenschap CommandLine door het volgende te typen:
[System.Environment]::Commandline
"C:\Program Files\Windows PowerShell\v1.0\powershell.exe"
Als u de versie van het besturingssysteem wilt controleren, geeft u de eigenschap OSVersion weer door het volgende te typen:
[System.Environment]::OSVersion
Platform ServicePack Version VersionString
-------- ----------- ------- -------------
Win32NT Service Pack 2 5.1.2600.131072 Microsoft Windows...
We kunnen controleren of de computer bezig is met afsluiten door de eigenschap HasShutdownStarted weer te geven:
[System.Environment]::HasShutdownStarted
False
Wiskunde uitvoeren met System.Math
De statische klasse System.Math is handig voor het uitvoeren van enkele wiskundige bewerkingen. De klasse bevat verschillende nuttige methoden, die we kunnen weergeven met behulp van Get-Member
.
Notitie
System.Math heeft verschillende methoden met dezelfde naam, maar ze worden onderscheiden door het type parameters.
Typ de volgende opdracht om de methoden van de klasse System.Math weer te geven.
[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...
Hiermee worden verschillende wiskundige methoden weergegeven. Hier volgt een lijst met opdrachten die laten zien hoe sommige van de algemene methoden werken:
[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
Feedback
https://aka.ms/ContentUserFeedback.
Binnenkort beschikbaar: In de loop van 2024 zullen we GitHub-problemen geleidelijk uitfaseren als het feedbackmechanisme voor inhoud en deze vervangen door een nieuw feedbacksysteem. Zie voor meer informatie:Feedback verzenden en weergeven voor