关于迭代的哈希表与自定义对象数组
Hashtable vs array of custom objects regarding iteration
我经常编写事物列表并针对它们执行枚举以执行一些 get/set。
我讨厌枚举哈希表,因为每当我必须这样做时,我都必须回过头来处理 hashtable
个对象。
$hashtablelistofitems = @{}
$hashtablelistofitems.add("i'm a key", "i'm a value")
foreach ($item in $hashtablelistofitems.keys) {
$item
$hashtablelistofitems.item($item)
}
相反,我通常恢复使用具有两个音符属性的自定义对象的一维数组。
$array = @()
$listofitems = "" | select key,value
$listofitems.key = "i'm a key"
$listofitems.value = "i'm a value"
$array += $listofitems
foreach ($item in $listofitems) {
$item.key
$item.value
}
为什么我应该使用 hashtable
而不是这种方法?仅仅因为它只保证每个键一个值?
如果要存储键值列表而不是创建包含具有两个属性(键/值)的自定义对象的数组,则应使用哈希表,主要有两个原因:
- 您可能希望将哈希表传递给需要哈希表的函数。
- Hashtable 是一种内置 PowerShell 类型,用户都知道。您的第二种方法对于其他用户来说更难阅读/维护。
注:
您可以通过调用 GetEnumerator()
函数以与您的方法几乎相同的方式迭代哈希表:
foreach ($item in $listofitems.GetEnumerator()) {
$item.key
$item.value
}
此外,哈希表附带了您可能想要使用的便捷方法:
@{} | Get-Member | Where-Object MemberType -eq Method | Select Name
输出:
Name
----
Add
Clear
Clone
Contains
ContainsKey
ContainsValue
CopyTo
Equals
GetEnumerator
GetHashCode
GetObjectData
GetType
OnDeserialization
Remove
ToString
这远没有 Martin 的纲要那么有用,但也足够有用了。
这是一篇关于如何在 Hashtables 和 PSCustomObjects 之间来回转换的 MSDN 文章。 The article
我经常编写事物列表并针对它们执行枚举以执行一些 get/set。
我讨厌枚举哈希表,因为每当我必须这样做时,我都必须回过头来处理 hashtable
个对象。
$hashtablelistofitems = @{}
$hashtablelistofitems.add("i'm a key", "i'm a value")
foreach ($item in $hashtablelistofitems.keys) {
$item
$hashtablelistofitems.item($item)
}
相反,我通常恢复使用具有两个音符属性的自定义对象的一维数组。
$array = @()
$listofitems = "" | select key,value
$listofitems.key = "i'm a key"
$listofitems.value = "i'm a value"
$array += $listofitems
foreach ($item in $listofitems) {
$item.key
$item.value
}
为什么我应该使用 hashtable
而不是这种方法?仅仅因为它只保证每个键一个值?
如果要存储键值列表而不是创建包含具有两个属性(键/值)的自定义对象的数组,则应使用哈希表,主要有两个原因:
- 您可能希望将哈希表传递给需要哈希表的函数。
- Hashtable 是一种内置 PowerShell 类型,用户都知道。您的第二种方法对于其他用户来说更难阅读/维护。
注:
您可以通过调用 GetEnumerator()
函数以与您的方法几乎相同的方式迭代哈希表:
foreach ($item in $listofitems.GetEnumerator()) {
$item.key
$item.value
}
此外,哈希表附带了您可能想要使用的便捷方法:
@{} | Get-Member | Where-Object MemberType -eq Method | Select Name
输出:
Name
----
Add
Clear
Clone
Contains
ContainsKey
ContainsValue
CopyTo
Equals
GetEnumerator
GetHashCode
GetObjectData
GetType
OnDeserialization
Remove
ToString
这远没有 Martin 的纲要那么有用,但也足够有用了。
这是一篇关于如何在 Hashtables 和 PSCustomObjects 之间来回转换的 MSDN 文章。 The article