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

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

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

    隨筆 - 4  文章 - 13  trackbacks - 0
    <2009年1月>
    28293031123
    45678910
    11121314151617
    18192021222324
    25262728293031
    1234567

    常用鏈接

    留言簿(1)

    隨筆檔案

    搜索

    •  

    最新評(píng)論

    閱讀排行榜

    評(píng)論排行榜

    情景上這樣的:我有一個(gè)重寫了equals方法的類,該類源碼如下。然后用一程序?qū)⒋祟惗啻窝h(huán)put到HashMap中去,但每次put到1500次左右時(shí),就會(huì)出現(xiàn)NullPointerException。
      在map.put的方法中,會(huì)先去判斷put進(jìn)去的對(duì)象是否已經(jīng)存在于map中,判斷方法調(diào)用的就是該對(duì)象的重寫的equals方法,如果說我寫的equals有問題的話,為什么前1000多次左右不會(huì)出現(xiàn)問題而在最后出現(xiàn)問題呢?起初以為是放到HashMap中的對(duì)象太大會(huì)出現(xiàn)內(nèi)存溢出,但并未出現(xiàn)outofmemory異常,用JProfiler進(jìn)行監(jiān)測(cè)時(shí)也發(fā)現(xiàn)和heap的使用也沒關(guān)系……有哪位兄弟幫我解釋一下……

      重寫了equals方法的類:
    public class myPolSchema {
        
    // @Field
        private String GrpContNo;
        
    private String GrpPolNo;

        
    public String getGrpContNo() {
            
    return GrpContNo;
        }


        
    public void setGrpContNo(String aGrpContNo) {
            GrpContNo 
    = aGrpContNo;
        }


        
    public String getGrpPolNo() {
            
    return GrpPolNo;
        }


        
    public void setGrpPolNo(String aGrpPolNo) {
            GrpPolNo 
    = aGrpPolNo;
        }


        
    public boolean equals(Object otherObject) {
            
    if (this == otherObject)
                
    return true;
            
    if (otherObject == null)
                
    return false;
            
    if (getClass() != otherObject.getClass())
                
    return false;
            myPolSchema other 
    = (myPolSchema) otherObject;
            
    return GrpContNo.equals(other.getGrpContNo())
                    
    && GrpPolNo.equals(other.getGrpPolNo());
        }

    }

    測(cè)試類:

    import java.util.* ;
    public class MultiThreading{
    // implements Runnable 
        Map m=Collections.synchronizedMap(new HashMap());
        
    //HashMap m=new HashMap();
        Hashtable t=new Hashtable();
        
    public myPolSchema polschema;
        
    public void run() 
        
    {
            polschema
    =new myPolSchema();
            m.put(polschema, 
    "UPDATE");
            System.out.println(
    "put end at " + new Date());
        }

        
    public static void main(String[] args) throws Exception {
            MultiThreading t
    =new MultiThreading();
            
    for(int i=0;i<=25000;i++){
                
    try{
                    t.run();
                    
    //Thread.sleep(100);
                }

                
    catch(Exception ex){
                    
    //在我本地測(cè)試時(shí)當(dāng)運(yùn)行大概1500左右次的時(shí)間就會(huì)拋出NullPointerException
                    System.out.println("i is: " + i);
                    
    throw ex;
                }

            }

        }


    }

    如果您有興趣,請(qǐng)下載這兩個(gè)類的源碼并實(shí)際測(cè)試:
    /Files/foxinsky/sourceCode.rar
    如果哪位兄臺(tái)有好的解決方案,請(qǐng)不吝賜教!
    posted on 2009-01-14 12:34 foxinsky 閱讀(1827) 評(píng)論(10)  編輯  收藏

    FeedBack:
    # re: 我無法解釋的問題,請(qǐng)您一并來解釋 2009-01-14 12:54 銀河使者
    只1500次,不可能產(chǎn)生內(nèi)存溢出異常,根據(jù)你的描述是拋出NullPointerException異常,這說明你引用了一個(gè)對(duì)象變量,但這個(gè)對(duì)象變量值為null,問題出在equals方法中,有可能出在下面的代碼中:

    myPolSchema other = (myPolSchema) otherObject;
    return GrpContNo.equals(other.getGrpContNo())
    && GrpPolNo.equals(other.getGrpPolNo());
    上面的代碼有可能other.getGrpConNo方法返回一個(gè)null,順便問一下,GrpContNo字段在什么時(shí)候賦的值?  回復(fù)  更多評(píng)論
      
    # re: 我無法解釋的問題,請(qǐng)您一并來解釋 2009-01-14 12:57 ourjavasky
    # re: 我無法解釋的問題,請(qǐng)您一并來解釋 2009-01-14 13:37 lvq810
    一樓是對(duì)的,類的屬性未賦值為Null,null值equals()就會(huì)出現(xiàn)NullPointerException  回復(fù)  更多評(píng)論
      
    # re: 我無法解釋的問題,請(qǐng)您一并來解釋 2009-01-14 13:39 Julia
    If you use object as key for Hashtable, you should override both
    equals() and hashCode() methods. Please see link

    http://www.ibm.com/developerworks/java/library/j-jtp05273.html
      回復(fù)  更多評(píng)論
      
    # re: 我無法解釋的問題,請(qǐng)您一并來解釋 2009-01-14 13:43 foxinsky
    @lvq810
    4樓給出的解釋應(yīng)該是正確的。下面是CSDN的網(wǎng)友MT502給出的解答:
    MAP在執(zhí)行put()的時(shí)候先調(diào)用myPolSchema的hashCode()方法看當(dāng)前有沒有一樣的hashCode存在,如果沒有就直接put,有的話就調(diào)用myPolSchema的equals()方法看是否相等。
    因?yàn)槟銢]有實(shí)現(xiàn)hashCode(),所以用默認(rèn)的hashCode(),所以當(dāng)產(chǎn)生相同的hashCode的時(shí)候(在我機(jī)器上是運(yùn)行到2058時(shí)),因?yàn)闄z查到相同的hashcode,所以調(diào)用你自己的equals(),因?yàn)镚rpContNo是null,所以這時(shí)候拋NullPointerException 。
    你機(jī)器上顯然是在1500的時(shí)候產(chǎn)生了相同了hashcode()。
    如果實(shí)現(xiàn)了hashCode(),第一次就拋NullPointerException :

    Java codepublic int hashCode() {
    final int prime = 31;
    int result = 1;
    result = prime * result
    + ((GrpContNo == null) ? 0 : GrpContNo.hashCode());
    result = prime * result
    + ((GrpPolNo == null) ? 0 : GrpPolNo.hashCode());
    return result;
    }


    我現(xiàn)在在想,如何去重寫hashCode方法才能保證生成的hashCode值不同呢……

    或者去修改我的equals算法,在調(diào)用之前先去判斷一下other.getGrpContNo==null(這兩種方法怎么實(shí)現(xiàn)起來才算是比較合理的算法呢?

      回復(fù)  更多評(píng)論
      
    # re: 我無法解釋的問題,請(qǐng)您一并來解釋 2009-01-14 13:57 lvq810
    只有修改equals加上判斷  回復(fù)  更多評(píng)論
      
    # re: 我無法解釋的問題,請(qǐng)您一并來解釋 2009-01-14 21:43 darkmagician
    如果equals是true,hashcode必須相同。 沒必要擔(dān)心不同的object有相同的hashcode, 否則還要equals干嘛, 保證hashcode分散,只是提高效率而已。  回復(fù)  更多評(píng)論
      
    # re: 我無法解釋的問題,請(qǐng)您一并來解釋[未登錄] 2009-01-15 08:40 nile black
    MAP在執(zhí)行put()的時(shí)候先調(diào)用myPolSchema的hashCode()方法看當(dāng)前有沒有一樣的hashCode存在,如果沒有就直接put,有的話就調(diào)用myPolSchema的equals()方法看是否相等。
    因?yàn)槟銢]有實(shí)現(xiàn)hashCode(),所以用默認(rèn)的hashCode(),所以當(dāng)產(chǎn)生相同的hashCode的時(shí)候(在我機(jī)器上是運(yùn)行到2058 時(shí)),因?yàn)闄z查到相同的hashcode,所以調(diào)用你自己的equals(),因?yàn)镚rpContNo是null,所以這時(shí)候拋 NullPointerException 。
    你機(jī)器上顯然是在1500的時(shí)候產(chǎn)生了相同了hashcode()。
    如果實(shí)現(xiàn)了hashCode(),第一次就拋NullPointerException :   回復(fù)  更多評(píng)論
      
    # re: 我無法解釋的問題,請(qǐng)您一并來解釋 2009-01-19 12:37 娃娃
    樓上這個(gè)師傅解釋很正確,學(xué)習(xí)了,記得考scjp的時(shí)候,有過一個(gè)題  回復(fù)  更多評(píng)論
      
    # re: 我無法解釋的問題,請(qǐng)您一并來解釋 2009-01-20 14:55 笨牛
    public class myPolSchema {
    private String GrpContNo;
    private String GrpPolNo;
    public String getGrpContNo() {
    return GrpContNo;
    }
    public void setGrpContNo(String aGrpContNo) {
    GrpContNo = aGrpContNo;
    }
    public String getGrpPolNo() {
    return GrpPolNo;
    }
    public void setGrpPolNo(String aGrpPolNo) {
    GrpPolNo = aGrpPolNo;
    }
    public myPolSchema(String GrpContNo,String GrpPolNo){
    this.GrpContNo=GrpContNo;
    this.GrpPolNo=GrpPolNo;
    }
    public boolean equals(Object otherObject) {
    if (this == otherObject)
    return true;
    if (otherObject == null)
    return false;
    if (getClass() != otherObject.getClass())
    return false;
    if(!(otherObject instanceof myPolSchema)){
    return false;
    }else{
    myPolSchema other = (myPolSchema) otherObject;
    return GrpContNo.equals(other.getGrpContNo())
    && GrpPolNo.equals(other.getGrpPolNo());
    }
    }

    }

    ---------------------------

    import java.util.* ;
    public class MultiThreading{
    // implements Runnable
    Map m=Collections.synchronizedMap(new HashMap());
    //HashMap m=new HashMap();
    Hashtable t=new Hashtable();
    public myPolSchema polschema;
    public void run(int i)
    {
    polschema=new myPolSchema(i+"",i+"");
    m.put(polschema, "UPDATE");
    System.out.println("put end at " + new Date());
    }
    public static void main(String[] args) throws Exception {
    MultiThreading t=new MultiThreading();
    for(int i=0;i<=25000;i++){
    try{
    t.run(i);
    //Thread.sleep(100);
    }
    catch(Exception ex){
    //在我本地測(cè)試時(shí)當(dāng)運(yùn)行大概1500左右次的時(shí)間就會(huì)拋出NullPointerException
    System.out.println("i is: " + i);
    throw ex;
    }
    }
    }

    }


    構(gòu)造方法啊大哥 不賦值怎么能比較呢  回復(fù)  更多評(píng)論
      

    只有注冊(cè)用戶登錄后才能發(fā)表評(píng)論。


    網(wǎng)站導(dǎo)航:
     
    主站蜘蛛池模板: 亚洲高清国产拍精品26U| 日韩成人免费aa在线看| 久久久精品国产亚洲成人满18免费网站| 亚洲欧美精品午睡沙发| 免费看黄视频网站| 亚洲va在线va天堂va手机| 日本免费xxxx| 精品亚洲456在线播放| 成年午夜视频免费观看视频| www.亚洲日本| 成人免费视频77777| 亚洲中文字幕无码久久2020| 精品国产免费观看一区| 青青青亚洲精品国产| 亚洲无码精品浪潮| a毛片在线免费观看| 亚洲视频在线观看视频| 最近2019中文字幕免费看最新| 亚洲乱人伦中文字幕无码| 免费一级特黄特色大片在线| kk4kk免费视频毛片| 亚洲人成在线观看| 成人看的午夜免费毛片| 黄色毛片免费网站| 亚洲va久久久噜噜噜久久天堂| 91久久成人免费| 亚洲国产高清国产拍精品| 亚洲中文字幕无码爆乳av中文| 成人毛片100免费观看| 亚洲国产成人精品久久| 国产免费AV片无码永久免费| 在线成人精品国产区免费| 亚洲AV成人无码天堂| 久久亚洲精品无码观看不卡| 亚洲最大免费视频网| 日韩毛片在线免费观看| 亚洲国产综合精品中文第一区 | 免费在线黄色电影| 亚洲一本之道高清乱码| 亚洲精品成人网久久久久久| 18禁黄网站禁片免费观看不卡|