<rt id="bn8ez"></rt>
<label id="bn8ez"></label>

  • <span id="bn8ez"></span>

    <label id="bn8ez"><meter id="bn8ez"></meter></label>

    love fish大鵬一曰同風起,扶搖直上九萬里

    常用鏈接

    統計

    積分與排名

    friends

    link

    最新評論

    hashcode重復的可能性超大(轉)

    用String的hashcode得到int類型作為主鍵。其實hashcode重復的可能性超大,下面是java的缺省算法:
     public int hashCode() {
        
    int h = hash;
        
    if (h == 0{
            
    int off = offset;
            
    char val[] = value;
            
    int len = count;

                
    for (int i = 0; i < len; i++{
                    h 
    = 31*+ val[off++];
                }

                hash 
    = h;
            }

            
    return h;
        }
    但是什么情況下會重復?下面是測試代碼




    import java.util.HashMap;

    public class Test {

        
    static HashMap map = new HashMap();

        
    private static char startChar = 'A';

        
    private static char endChar = 'z';

        
    private static int offset = endChar - startChar + 1;

        
    private static int dup = 0;

        
    public static void main(String[] args) {
            
    int len = 3;
            
    char[] chars = new char[len];
            tryBit(chars, len);
            System.
    out.println((int)Math.pow(offset, len) + ":" + dup);
        }


        
    private static void tryBit(char[] chars, int i) {
            
    for (char j = startChar; j <= endChar; j++{
                chars[i 
    - 1= j;
                
    if (i > 1)
                    tryBit(chars, i 
    - 1);
                
    else
                    test(chars);
            }

        }


        
    private static void test(char[] chars) {

            String str 
    = new String(chars).replaceAll("[^a-zA-Z_]""").toUpperCase();// 195112:0
            
    //String str = new String(chars).toLowerCase();//195112:6612
            
    //String str = new String(chars).replaceAll("[^a-zA-Z_]","");//195112:122500
            
    //String str = new String(chars);//195112:138510
            int hash = str.hashCode();
            
    if (map.containsKey(hash)) {
                String s 
    = (String) map.get(hash);
                
    if (!s.equals(str)) {
                    dup
    ++;
                    System.
    out.println(s + ":" + str);
                }

            }
     else {
                map.put(hash, str);
                
    // System.out.println(str);
            }

        }

    }


    在A-z范圍內有特殊字符,從結果看,僅僅3位長度的字符串:
    不處理: 138510次重復
    去掉字母意外字符: 122500次重復
    所有字符轉小寫:6612次重復(少了很多)
    去掉字母意外字符,并且轉小寫:沒有重復!4位字符串也沒見重復

    不難看出:
    1. 缺省實現為英文字母優化
    2. 字母大小寫可能導致重復

    可能:
    長字符串可能hashcode重復
    中文字符串和特殊字符可能hashcode重復

    posted on 2006-06-25 10:34 liaojiyong 閱讀(1463) 評論(0)  編輯  收藏 所屬分類: Java

    主站蜘蛛池模板: 精品国产亚洲一区二区三区| 三年片在线观看免费| 免费精品国产自产拍在线观看图片| 国产成人亚洲精品91专区手机| 78成人精品电影在线播放日韩精品电影一区亚洲| 久久亚洲AV无码精品色午夜| 国内精品免费在线观看| 亚洲国产精品VA在线观看麻豆| aaa毛片免费观看| 亚洲av日韩av不卡在线观看| 99热这里有免费国产精品| 亚洲无圣光一区二区| 国产一卡2卡3卡4卡2021免费观看| wwwxxx亚洲| 国产又粗又猛又爽又黄的免费视频| 亚洲熟妇无码一区二区三区| 四虎永久在线精品免费影视| 一级毛片免费视频网站| 亚洲va无码va在线va天堂| 国产电影午夜成年免费视频 | 亚洲人成电影网站国产精品| 一个人看的www在线免费视频| 亚洲国产精品高清久久久| 永久在线观看www免费视频| 亚洲熟妇成人精品一区| 亚洲精品无码你懂的网站| 免费看一区二区三区四区| 亚洲av极品无码专区在线观看| 国产伦精品一区二区三区免费下载| 日韩a级无码免费视频| 成人免费av一区二区三区| 亚洲香蕉网久久综合影视 | 一个人看的hd免费视频| 无码专区—VA亚洲V天堂| 成人超污免费网站在线看| 美女又黄又免费的视频| 亚洲爆乳无码一区二区三区| 久久99国产综合精品免费| 精品亚洲av无码一区二区柚蜜| 亚洲精品国精品久久99热一| 成人毛片免费播放|