Nem todas as classes do .NET Framework podem ser criadas com o uso de New-Object. Por exemplo, se você tentar criar um objeto System.Environment ou System.Math com New-Object, obterá as seguintes mensagens de erro:

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

Esses erros ocorrem porque não há uma maneira de criar um novo objeto a partir dessas classes. Elas são bibliotecas de referências de métodos e propriedades que não alteram seu estado. Você não precisa criá-las, mas simplesmente as utiliza. Classes e métodos como esses são chamados classes estáticas porque não são criados, destruídos ou alterados. Para esclarecermos esse assunto, mostraremos alguns exemplos que utilizam classes estáticas.

Obtendo dados do ambiente com System.Environment

Normalmente, a primeira etapa ao se trabalhar com um objeto no Windows PowerShell é usar Get-Member para descobrir quais membros ele contém. Com as classes estáticas, o processo é um pouco diferente porque a classe verdadeira não é um objeto.

Referência à classe estática System.Environment

Você pode se referir a uma classe estática colocando o nome da classe entre colchetes. Por exemplo, você pode fazer referência a System.Environment digitando o nome entre colchetes. Ao fazer isso, serão exibidas algumas informações genéricas sobre o tipo:

PS> [System.Environment]

IsPublic IsSerial Name                                     BaseType
-------- -------- ----                                     --------
True     False    Environment                              System.Object
Observação:

Como mencionamos anteriormente, o Windows PowerShell adiciona automaticamente 'System.' ao início dos nomes de tipos quando você usa New-Object. O mesmo acontece quando usamos um nome de tipo entre colchetes, portanto é possível especificar [System.Environment] como [Environment].

A classe System.Environment contém informações gerais sobre o ambiente de trabalho do processo atual, que será powershell.exe quando estivermos trabalhando no Windows PowerShell.

Se você tentar exibir detalhes dessa classe digitando [System.Environment] | Get-Member, o tipo de objeto será informado como sendo System.RuntimeType, não System.Environment:

PS> [System.Environment] | Get-Member

   TypeName: System.RuntimeType

Para exibir membros estáticos com Get-Member, especifique o parâmetro 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

Agora podemos selecionar propriedades para serem exibidas a partir de System.Environment.

Exibindo as propriedades estáticas de System.Environment

As propriedades de System.Environment também são estáticas, e devem ser especificadas de uma maneira diferente das propriedades normais. Usamos :: para indicar ao Windows PowerShell que queremos trabalhar com um método ou uma propriedade estática. Para exibir o comando usado para iniciar o Windows PowerShell, verificamos a propriedade CommandLine digitando:

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

Para verificar a versão do sistema operacional, exiba a propriedade OSVersion, digitando:

PS> [System.Environment]::OSVersion

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

Podemos verificar se o computador está em processo de desligamento com a exibição da propriedade HasShutdownStarted :

PS> [System.Environment]::HasShutdownStarted
False  

Executando cálculos matemáticos com System.Math

A classe estática System.Math é útil para a execução de algumas operações matemáticas. Os membros importantes de System.Math são, em sua maioria, métodos, que podemos exibir usando Get-Member.

Observação:

System.Math possui vários métodos com o mesmo nome, mas que se distinguem pelo tipo de seus parâmetros.

Digite o comando a seguir para listar os métodos da classe 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...

Isso exibe vários métodos matemáticos. A seguir, uma lista de comandos que demonstram como funcionam alguns dos métodos mais comuns:

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




Sumário