关于迭代的哈希表与自定义对象数组

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 而不是这种方法?仅仅因为它只保证每个键一个值?

如果要存储键值列表而不是创建包含具有两个属性(键/值)的自定义对象的数组,则应使用哈希表,主要有两个原因:

  1. 您可能希望将哈希表传递给需要哈希表的函数。
  2. 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