D 语言 - 关联数组
关联数组的索引不一定是整数,并且可以稀疏填充。 关联数组的索引称为Key,其类型称为KeyType。
关联数组是通过将 KeyType 放置在数组声明的 [ ] 内来声明的。 下面显示了关联数组的一个简单示例。
import std.stdio; void main () { int[string] e; // 整数的关联数组 b 是 e["test"] = 3; writeln(e["test"]); string[string] f; f["test"] = "Tuts"; writeln(f["test"]); writeln(f); f.remove("test"); writeln(f); }
当上面的代码被编译并执行时,会产生以下结果 −
3 Tuts ["test":"Tuts"] []
初始化关联数组
下面显示了关联数组的简单初始化。
import std.stdio; void main () { int[string] days = [ "Monday" : 0, "Tuesday" : 1, "Wednesday" : 2, "Thursday" : 3, "Friday" : 4, "Saturday" : 5, "Sunday" : 6 ]; writeln(days["Tuesday"]); }
当上面的代码被编译并执行时,会产生以下结果 −
1
关联数组的属性
这是关联数组的属性 −
序号 | 属性和描述 |
---|---|
1 | .sizeof 返回关联数组的引用大小; 在 32 位版本中为 4,在 64 位版本中为 8。 |
2 | .length 返回关联数组中的值的数量。 与动态数组不同,它是只读的。 |
3 | .dup 创建一个相同大小的新关联数组并将关联数组的内容复制到其中。 |
4 | .keys 返回动态数组,其元素是关联数组中的键。 |
5 | .values 返回动态数组,其元素是关联数组中的值。 |
6 | .rehash 重新组织关联数组,以便查找更加高效。 例如,当程序完成加载符号表并且现在需要在其中快速查找时,重新散列是有效的。 返回对重新组织的数组的引用。 |
7 | .byKey() 返回适合用作 ForeachStatement 聚合的委托,该委托将迭代关联数组的 Key 键。 |
8 | .byValue() 返回适合用作 ForeachStatement 聚合的委托,该委托将迭代关联数组的 value 值。 |
9 | .get(Key key, lazy Value defVal) 查找 Key 键; 如果存在则返回相应的值,否则计算并返回 defVal。 |
10 | .remove(Key key) 删除键的对象。 |
示例
下面显示了使用上述属性的示例。
import std.stdio; void main () { int[string] array1; array1["test"] = 3; array1["test2"] = 20; writeln("sizeof: ",array1.sizeof); writeln("length: ",array1.length); writeln("dup: ",array1.dup); array1.rehash; writeln("rehashed: ",array1); writeln("keys: ",array1.keys); writeln("values: ",array1.values); foreach (key; array1.byKey) { writeln("by key: ",key); } foreach (value; array1.byValue) { writeln("by value ",value); } writeln("get value for key test: ",array1.get("test",10)); writeln("get value for key test3: ",array1.get("test3",10)); array1.remove("test"); writeln(array1); }
当上面的代码被编译并执行时,会产生以下结果 −
sizeof: 8 length: 2 dup: ["test":3, "test2":20] rehashed: ["test":3, "test2":20] keys: ["test", "test2"] values: [3, 20] by key: test by key: test2 by value 3 by value 20 get value for key test: 3 get value for key test3: 10 ["test2":20]