在 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
orNew-Struct
将让您实际测试您的课程param([Contact]$contact)
并使用$contact = new-object Contact
等等...
在 PowerShell 3 中
如果您不需要可以转换为的“真实”类,则不必使用Steven 和其他人在上面演示的 Add-Member 方式。
从 PowerShell 2 开始,您可以对 New-Object 使用 -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
{
# Optionally, add attributes to prevent invalid values
[ValidateNotNullOrEmpty()][string]$First
[ValidateNotNullOrEmpty()][string]$Last
[ValidateNotNullOrEmpty()][string]$Phone
# optionally, have a constructor to
# force properties to be set:
Contact($First, $Last, $Phone) {
$this.First = $First
$this.Last = $Last
$this.Phone = $Phone
}
}
我们还获得了一种不使用以下方法来创建对象的新方法New-Object
:[Contact]::new()
-- 事实上,如果您保持类简单并且不定义构造函数,则可以通过强制转换哈希表来创建对象(尽管没有构造函数,就没有办法强制必须设置所有属性):
class Contact
{
# Optionally, add attributes to prevent invalid values
[ValidateNotNullOrEmpty()][string]$First
[ValidateNotNullOrEmpty()][string]$Last
[ValidateNotNullOrEmpty()][string]$Phone
}
$C = [Contact]@{
First = "Joel"
Last = "Bennett"
}