Domanda

Cosa utilizza Java come metodo di sondaggio predefinito per HashMap? È lineare? Concatenare o qualcos'altro?

È stato utile?

Soluzione

Sembra concatenarmi. Codice: (link)

...
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);
...

Cioè, prendi la voce su bucketIndex, quindi sostituiscila con una nuova voce che ha come "successivo" campo la voce che era già lì (cioè incatenalo).

Autorizzato sotto: CC-BY-SA insieme a attribuzione
Non affiliato a StackOverflow
scroll top