Поделиться через


Использование статических классов и методов

Не все платформа .NET Framework классы можно создавать с помощьюNew-Object. Например, при попытке создать объект New-ObjectSystem.Environment или System.Math вы получите следующие сообщения об ошибках:

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

Эти ошибки вызваны тем, что из таких классов нельзя создать объект. Эти классы являются ссылочными библиотеками методов и свойств, которые не изменяют состояние. Их не нужно создавать, а можно просто использовать. Классы и методы, такие как эти, называются статическими классами , поскольку они не создаются, уничтожаются или изменяются. В качестве пояснения мы представим примеры, использующие статические классы.

Получение данных среды с помощью System.Environment

Обычно первый шаг при работе с объектом в Windows PowerShell — использовать Get-Member, чтобы выяснить, какие элементы он содержит. В статических классах процесс немного отличается, так как фактический класс не является объектом.

Ссылка на статический класс System.Environment

Сослаться на статический класс можно, заключив его имя в квадратные скобки. Например, можно ссылаться на System.Environment, введя его имя в квадратные скобки. При этом отображаются сведения об универсальном типе:

[System.Environment]
IsPublic IsSerial Name                                     BaseType
-------- -------- ----                                     --------
True     False    Environment                              System.Object

Примечание.

Как упоминалось ранее, Windows PowerShell автоматически добавляет "System." для ввода имен при использовании New-Object. То же самое происходит и при использовании имени типа в квадратных скобках, поэтому можно указать [System.Environment] как [Environment].

Класс System.Environment содержит общие сведения о рабочей среде для текущего процесса (powershell.exe при работе в Windows PowerShell).

Если попытаться просмотреть описание этого класса, введя [System.Environment] | Get-Member, тип объекта указывается как System.RuntimeType, а не System.Environment:

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

Чтобы просмотреть статические элементы с помощью Get-Member, укажите параметр 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

Теперь можно выбрать свойства для просмотра из System.Environment.

Отображение статических свойств System.Environment

Свойства System.Environment также являются статическими и должны быть указаны иначе, чем обычные свойства. Мы используем для :: указания Windows PowerShell, что мы хотим работать со статическим методом или свойством. Чтобы просмотреть команду, которая использовалась для запуска Windows PowerShell, мы проверяем свойство CommandLine, введя следующее:

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

Чтобы проверить версию операционной системы, отобразите свойство OSVersion, введя следующее:

[System.Environment]::OSVersion
           Platform ServicePack         Version             VersionString
           -------- -----------         -------             -------------
            Win32NT Service Pack 2      5.1.2600.131072     Microsoft Windows...

Можно проверить, находится ли компьютер в процессе завершения работы, отобразив свойство HasShutdownStarted:

[System.Environment]::HasShutdownStarted
False

Выполнение математики с помощью System.Math

Статический класс System.Math полезен для выполнения некоторых математических операций. Класс включает несколько полезных методов, которые можно отобразить с помощью Get-Member.

Примечание.

System.Math имеет несколько методов с одинаковым именем, но они различаются по типу их параметров.

Введите следующую команду, чтобы получить список методов для класса 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...

При этом отображается несколько математических методов. Ниже приведен список команд, которые демонстрируют работу некоторых распространенных методов:

[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