Pregunta

¿Qué utiliza Java como método de sondeo predeterminado para HashMap? ¿Es lineal? ¿Encadenamiento o algo más?

¿Fue útil?

Solución

Parece encadenarme. Código: (enlace)

...
724         /**
725          * Create new entry.
726          */
727         Entry(int h, K k, V v, Entry n) {
728             value = v;
729             next = n;
730             key = k;
731             hash = h;
732         }
...

...
795     void addEntry(int hash, K key, V value, int bucketIndex) {
796     Entry e = table[bucketIndex];
797         table[bucketIndex] = new Entry(hash, key, value, e);
...

Es decir, tome la entrada en bucketIndex, luego reemplácela por una nueva entrada que tenga como '' siguiente '' campo la entrada que ya estaba allí (es decir, encadenarla).

Licenciado bajo: CC-BY-SA con atribución
No afiliado a StackOverflow
scroll top