การเขียนโปรแกรม D - อาร์เรย์ที่เกี่ยวข้อง
Associative arrays มีดัชนีที่ไม่จำเป็นต้องเป็นจำนวนเต็มและอาจมีข้อมูลเบาบาง ดัชนีสำหรับอาร์เรย์ที่เชื่อมโยงเรียกว่าKeyและประเภทของมันเรียกว่า KeyType.
Associative arrays ถูกประกาศโดยการวาง 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"]
[]
การเริ่มต้น Associative Array
การเริ่มต้นอย่างง่ายของอาร์เรย์เชื่อมโยงแสดงอยู่ด้านล่าง
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
คุณสมบัติของ Associative Array
นี่คือคุณสมบัติของอาร์เรย์ที่เชื่อมโยง -
ซีเนียร์ | คุณสมบัติและคำอธิบาย |
---|---|
1 | .sizeof ส่งคืนขนาดของการอ้างอิงไปยังอาร์เรย์ที่เชื่อมโยง เป็นแบบ 4 ใน 32 บิตและ 8 ในรุ่น 64 บิต |
2 | .length ส่งคืนจำนวนค่าในอาร์เรย์ที่เชื่อมโยง ไม่เหมือนกับอาร์เรย์แบบไดนามิกคืออ่านอย่างเดียว |
3 | .dup สร้างอาร์เรย์เชื่อมโยงใหม่ที่มีขนาดเท่ากันและคัดลอกเนื้อหาของอาร์เรย์ที่เชื่อมโยงลงไป |
4 | .keys ส่งคืนอาร์เรย์แบบไดนามิกซึ่งเป็นองค์ประกอบที่เป็นคีย์ในอาร์เรย์ที่เชื่อมโยงกัน |
5 | .values ส่งคืนอาร์เรย์แบบไดนามิกซึ่งเป็นองค์ประกอบที่เป็นค่าในอาร์เรย์ที่เชื่อมโยงกัน |
6 | .rehash จัดเรียงอาร์เรย์ที่เชื่อมโยงใหม่เพื่อให้การค้นหามีประสิทธิภาพมากขึ้น การรีแฮชจะมีผลเมื่อเช่นโปรแกรมโหลดตารางสัญลักษณ์เสร็จแล้วและตอนนี้ต้องการการค้นหาอย่างรวดเร็ว ส่งคืนการอ้างอิงไปยังอาร์เรย์ที่จัดระเบียบใหม่ |
7 | .byKey() ส่งคืนผู้รับมอบสิทธิ์ที่เหมาะสำหรับใช้เป็น Aggregate เป็น ForeachStatement ซึ่งจะวนซ้ำบนคีย์ของอาร์เรย์ที่เชื่อมโยง |
8 | .byValue() ส่งคืนผู้รับมอบสิทธิ์ที่เหมาะสมสำหรับใช้เป็น Aggregate ไปยัง ForeachStatement ซึ่งจะวนซ้ำค่าของอาร์เรย์ที่เชื่อมโยง |
9 | .get(Key key, lazy Value defVal) ค้นหาคีย์; หากมีอยู่จะส่งคืนค่าที่สอดคล้องกันอื่น ๆ จะประเมินและส่งคืนค่า 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]