在PowerShell 3之前
PowerShell的可扩展类型系统最初不允许您创建可以根据参数设置方法进行测试的具体类型。如果您不需要该测试,则可以使用上述任何其他方法。
如果您想要一个可以转换为或进行类型检查的实际类型,例如在示例脚本中……除非将其写入C#或VB.net并进行编译,否则无法完成。在PowerShell 2中,您可以使用“ Add-Type”命令来简化它:
add-type @"
public struct contact {
public string First;
public string Last;
public string Phone;
}
"@
历史注释:在PowerShell 1中,它甚至更难。您必须手动使用CodeDom,PoshCode.org上有一个非常老的函数new-struct脚本,可以帮助您。您的示例变为:
New-Struct Contact @{
First=[string];
Last=[string];
Phone=[string];
}
使用Add-Type
或New-Struct
将让您实际测试自己的班级,param([Contact]$contact)
并使用$contact = new-object Contact
等创建新班级...
在PowerShell 3中
如果不需要可以转换为的“真实”类,则不必使用Steven和其他人在上面演示的Add-Member方法。
从PowerShell 2开始,可以对新对象使用-Property参数:
$Contact = New-Object PSObject -Property @{ First=""; Last=""; Phone="" }
在PowerShell 3中,我们可以使用PSCustomObject
加速器添加TypeName:
[PSCustomObject]@{
PSTypeName = "Contact"
First = $First
Last = $Last
Phone = $Phone
}
您仍然只得到一个对象,因此您应该创建一个New-Contact
函数以确保每个对象都相同,但是现在可以通过使用PSTypeName
属性装饰参数来轻松地验证参数“是”其中一种类型:
function PrintContact
{
param( [PSTypeName("Contact")]$contact )
"Customer Name is " + $contact.First + " " + $contact.Last
"Customer Phone is " + $contact.Phone
}
在PowerShell 5中
在PowerShell 5中,一切都发生了变化,最后我们得到了class
和enum
作为用于定义类型的语言关键字(没有,struct
但是没关系):
class Contact
{
[ValidateNotNullOrEmpty()][string]$First
[ValidateNotNullOrEmpty()][string]$Last
[ValidateNotNullOrEmpty()][string]$Phone
Contact($First, $Last, $Phone) {
$this.First = $First
$this.Last = $Last
$this.Phone = $Phone
}
}
我们还提供了一种无需使用New-Object
以下对象即可创建对象的新方法:[Contact]::new()
-实际上,如果使类保持简单并且不定义构造函数,则可以通过强制转换哈希表来创建对象(尽管没有构造函数,也无法强制必须设置所有属性):
class Contact
{
[ValidateNotNullOrEmpty()][string]$First
[ValidateNotNullOrEmpty()][string]$Last
[ValidateNotNullOrEmpty()][string]$Phone
}
$C = [Contact]@{
First = "Joel"
Last = "Bennett"
}