GetHashCode existeix principalment amb un propòsit: per servir com a funció hash quan l'objecte s'utilitza com a clau en una taula hash. … Una taula hash és una estructura de dades que associa un valor amb una clau.
Quin és l'objectiu de GetHashCode?
El mètode GetHashCode proporciona aquest codi hash per als algorismes que necessiten comprovacions ràpides de la igu altat d'objectes Per obtenir informació sobre com s'utilitzen els codis hash a les taules hash i per a alguns algorismes de codi hash addicionals, vegeu l'entrada Funció hash a la Viquipèdia. Dos objectes que són iguals retornen codis hash que són iguals.
Necessito implementar GetHashCode?
És important implementar tant equals com gethashcode, a causa de les col·lisions, en particular quan s'utilitzen diccionaris. si dos objectes retornen el mateix codi hash, s'insereixen al diccionari amb l'encadenament. Mentre s'utilitza el mètode d'accés a l'element iguals.
Quan hem d'anul·lar GetHashCode?
Si esteu implementant un tipus de referència, hauríeu de considerar substituir el mètode Equals si el vostre tipus sembla un tipus base, com ara Point, String, BigNumber, etc. Substituïu el mètode GetHashCode per permetre que a tipus funcioni correctament en una taula hash Llegiu més instruccions sobre operadors d'igu altat.
Què és un hash al codi?
Hash és simplement passar algunes dades a través d'una fórmula que produeix un resultat, anomenat hash. Aquest hash sol ser una cadena de caràcters i els hash generats per una fórmula sempre tenen la mateixa longitud, independentment de la quantitat de dades que hi introduïu. Per exemple, la fórmula MD5 sempre produeix 32 hash de caràcters.