- D 编程基础
- D 编程 - 主页
- D 编程 - 概述
- D 编程 - 环境
- D 编程 - 基本语法
- D 编程 - 变量
- D 编程 - 数据类型
- D 编程 - 枚举
- D 编程 - 文字
- D 编程 - 运算符
- D 编程 - 循环
- D 编程 - 决策
- D 编程 - 函数
- D 编程 - 字符
- D 编程 - 字符串
- D 编程 - 数组
- D 编程 - 关联数组
- D 编程 - 指针
- D 编程 - 元组
- D 编程 - 结构
- D 编程 - 联合
- D 编程 - 范围
- D 编程 - 别名
- D 编程 - Mixins
- D 编程 - 模块
- D 编程 - 模板
- D 编程 - 不可变
- D 编程 - 文件 I/O
- D 编程 - 并发
- D 编程 - 异常处理
- D 编程 - 合同
- D - 条件编译
- D 编程 - 面向对象
- D 编程 - 类和对象
- D 编程 - 继承
- D 编程 - 重载
- D 编程 - 封装
- D 编程 - 接口
- D 编程 - 抽象类
- D 编程 - 有用的资源
- D 编程 - 快速指南
- D 编程 - 有用的资源
- D 编程 - 讨论
D 编程 - 关联数组
关联数组的索引不一定是整数,并且可以稀疏填充。关联数组的索引称为 Key ,其类型称为KeyType。
关联数组是通过将 KeyType 放置在数组声明的 [ ] 内来声明的。下面显示了关联数组的一个简单示例。
import std.stdio;
void main () {
int[string] e; // associative array b of ints that are
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 | 。长度 返回关联数组中的值的数量。与动态数组不同,它是只读的。 |
| 3 | .dup 创建一个相同大小的新关联数组并将关联数组的内容复制到其中。 |
| 4 | .keys 返回动态数组,其元素是关联数组中的键。 |
| 5 | .values 返回动态数组,其元素是关联数组中的值。 |
| 6 | .rehash 重新组织关联数组,使查找更加高效。例如,当程序完成加载符号表并且现在需要在其中快速查找时,重新散列是有效的。返回对重新组织的数组的引用。 |
| 7 | .byKey() 返回适合用作 ForeachStatement 的聚合的委托,该委托将迭代关联数组的键。 |
| 8 | .byValue() 返回适合用作 ForeachStatement 聚合的委托,该委托将迭代关联数组的值。 |
| 9 | .get(Key key, 惰性值 defVal) 查找键;如果存在则返回相应的值,否则计算并返回 defVal。 |
| 10 | .remove(关键键) 删除键的对象。 |
例子
下面显示了使用上述属性的示例。
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]