Не все классы .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