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

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

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

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

Обычно при работе с объектом в оболочке Windows PowerShell в первую очередь используется командлет Get-Member для просмотра элементов объекта. Для статических классов эта процесс выглядит несколько иначе, поскольку класс не является объектом как таковым.

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

Обращение к статическому классу возможно при заключении имени класса в квадратные скобки. Например, ссылка на System.Environment состоит из имени класса внутри скобок. Такая команда приводит к выводу общих сведений:

PS> [System.Environment]

IsPublic IsSerial Name									 BaseType
-------- -------- ----									 --------
True	 False	Environment							System.Object
Примечание.

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

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

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

PS> [System.Environment] | Get-Member

   TypeName: System.RuntimeType

Для просмотра статических элементов с помощью командлета Get-Member укажите параметр Static :

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

После этого свойства класса System.Environment можно выбрать для просмотра.

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

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

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

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

PS> [System.Environment]::OSVersion

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

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

PS> [System.Environment]::HasShutdownStarted
False  

Вычислительные действия с помощью класса System.Math

Статический класс System.Math используется для выполнения некоторых математических вычислений. Большинство важных элементов класса System.Math является методами, которые можно вывести командлетом Get-Member.

Примечание.

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

Чтобы вывести список методов класса System.Math, введите следующую команду:

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

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

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