Programação D - Matrizes associativas
As matrizes associativas têm um índice que não é necessariamente um número inteiro e podem ser preenchidas de forma esparsa. O índice de uma matriz associativa é chamado deKey, e seu tipo é chamado de KeyType.
As matrizes associativas são declaradas colocando o KeyType dentro de [] de uma declaração de matriz. Um exemplo simples de array associativo é mostrado abaixo.
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);
}
Quando o código acima é compilado e executado, ele produz o seguinte resultado -
3
Tuts
["test":"Tuts"]
[]
Inicializando Matriz Associativa
Uma inicialização simples de matriz associativa é mostrada abaixo.
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"]);
}
Quando o código acima é compilado e executado, ele produz o seguinte resultado -
1
Propriedades da Matriz Associativa
Aqui estão as propriedades de uma matriz associativa -
Sr. Não. | Descrição da Propriedade |
---|---|
1 | .sizeof Retorna o tamanho da referência ao array associativo; é 4 em compilações de 32 bits e 8 em compilações de 64 bits. |
2 | .length Retorna o número de valores na matriz associativa. Ao contrário dos arrays dinâmicos, é somente leitura. |
3 | .dup Crie uma nova matriz associativa do mesmo tamanho e copie o conteúdo da matriz associativa para ela. |
4 | .keys Retorna a matriz dinâmica, cujos elementos são as chaves da matriz associativa. |
5 | .values Retorna a matriz dinâmica, cujos elementos são os valores da matriz associativa. |
6 | .rehash Reorganiza a matriz associativa no local para que as pesquisas sejam mais eficientes. O rehash é eficaz quando, por exemplo, o programa termina de carregar uma tabela de símbolos e agora precisa de pesquisas rápidas nela. Retorna uma referência à matriz reorganizada. |
7 | .byKey() Retorna um delegado adequado para uso como um Aggregate para um ForeachStatement que irá iterar sobre as chaves da matriz associativa. |
8 | .byValue() Retorna um delegado adequado para uso como um Aggregate para um ForeachStatement que irá iterar sobre os valores da matriz associativa. |
9 | .get(Key key, lazy Value defVal) Procura a chave; se existir, retorna o valor correspondente, então avalia e retorna defVal. |
10 | .remove(Key key) Remove um objeto para a chave. |
Exemplo
Um exemplo de uso das propriedades acima é mostrado abaixo.
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);
}
Quando o código acima é compilado e executado, ele produz o seguinte resultado -
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]