Consulte How Hashes Really Work para una discusión sobre este tema. En resumen, siempre que cite la clave (sin interpolación q {}), puede usar los caracteres que desee.
Con respecto a la respuesta de Dana, no, no tomará más tiempo para que coincidan las claves más largas: la clave tardará infinitesimalmente más tiempo, pero eso es todo.
de referencia, esta es la función hash en Perl 5.10.0:
#define PERL_HASH(hash,str,len)
STMT_START {
register const char * const s_PeRlHaSh_tmp = str;
register const unsigned char *s_PeRlHaSh = (const unsigned char *)s_PeRlHaSh_tmp;
register I32 i_PeRlHaSh = len;
register U32 hash_PeRlHaSh = PERL_HASH_SEED;
while (i_PeRlHaSh--) {
hash_PeRlHaSh += *s_PeRlHaSh++;
hash_PeRlHaSh += (hash_PeRlHaSh << 10);
hash_PeRlHaSh ^= (hash_PeRlHaSh >> 6);
}
hash_PeRlHaSh += (hash_PeRlHaSh << 3);
hash_PeRlHaSh ^= (hash_PeRlHaSh >> 11);
(hash) = (hash_PeRlHaSh + (hash_PeRlHaSh << 15));
} STMT_END
+1 para la dirección :) –