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]