Hashtable与关于迭代的自定义对象数组

mbr*_*nyc 6 powershell hashtable key-value-store

我经常编写事物列表并对它们执行枚举以执行一些get/set.

我讨厌枚举哈希表,因为每当我必须这样做时,我必须向后弯曲以处理hashtable对象.

$hashtablelistofitems = @{}

$hashtablelistofitems.add("i'm a key", "i'm a value")

foreach ($item in $hashtablelistofitems.keys) {
  $item
  $hashtablelistofitems.item($item)
}
Run Code Online (Sandbox Code Playgroud)

相反,我通常会恢复使用具有两个noteproperties的自定义对象的单维数组.

$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
}
Run Code Online (Sandbox Code Playgroud)

我为什么要使用hashtable这种方法呢?仅仅因为它只保证每个键的单个值?

Mar*_*ndl 6

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

  1. 您可能希望将哈希表传递给期望哈希表的函数.
  2. Hashtable是用户都知道的内置 PowerShell类型.您的第二种方法对于其他用户来说更难以阅读/维护.

注意: 您可以通过调用GetEnumerator()函数来迭代哈希表,几乎与您的方法相同:

foreach ($item in $listofitems.GetEnumerator()) {
  $item.key
  $item.value
}
Run Code Online (Sandbox Code Playgroud)

此外,哈希表还带有您可能想要使用的方便方法:

@{} | Get-Member | Where-Object MemberType -eq Method | Select Name
Run Code Online (Sandbox Code Playgroud)

输出:

Name             
----             
Add              
Clear            
Clone            
Contains         
ContainsKey      
ContainsValue    
CopyTo           
Equals           
GetEnumerator    
GetHashCode      
GetObjectData    
GetType          
OnDeserialization
Remove           
ToString  
Run Code Online (Sandbox Code Playgroud)