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

    隨筆檔案

    搜索

    •  

    最新評論

    閱讀排行榜

    評論排行榜

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

    }

    測試類:

    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){
                    
    //在我本地測試時當(dāng)運行大概1500左右次的時間就會拋出NullPointerException
                    System.out.println("i is: " + i);
                    
    throw ex;
                }

            }

        }


    }

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

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

    myPolSchema other = (myPolSchema) otherObject;
    return GrpContNo.equals(other.getGrpContNo())
    && GrpPolNo.equals(other.getGrpPolNo());
    上面的代碼有可能other.getGrpConNo方法返回一個null,順便問一下,GrpContNo字段在什么時候賦的值?  回復(fù)  更多評論
      
    # re: 我無法解釋的問題,請您一并來解釋 2009-01-14 12:57 ourjavasky
    # re: 我無法解釋的問題,請您一并來解釋 2009-01-14 13:37 lvq810
    一樓是對的,類的屬性未賦值為Null,null值equals()就會出現(xiàn)NullPointerException  回復(fù)  更多評論
      
    # re: 我無法解釋的問題,請您一并來解釋 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ù)  更多評論
      
    # re: 我無法解釋的問題,請您一并來解釋 2009-01-14 13:43 foxinsky
    @lvq810
    4樓給出的解釋應(yīng)該是正確的。下面是CSDN的網(wǎng)友MT502給出的解答:
    MAP在執(zhí)行put()的時候先調(diào)用myPolSchema的hashCode()方法看當(dāng)前有沒有一樣的hashCode存在,如果沒有就直接put,有的話就調(diào)用myPolSchema的equals()方法看是否相等。
    因為你沒有實現(xiàn)hashCode(),所以用默認(rèn)的hashCode(),所以當(dāng)產(chǎn)生相同的hashCode的時候(在我機(jī)器上是運行到2058時),因為檢查到相同的hashcode,所以調(diào)用你自己的equals(),因為GrpContNo是null,所以這時候拋NullPointerException 。
    你機(jī)器上顯然是在1500的時候產(chǎn)生了相同了hashcode()。
    如果實現(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(這兩種方法怎么實現(xiàn)起來才算是比較合理的算法呢?

      回復(fù)  更多評論
      
    # re: 我無法解釋的問題,請您一并來解釋 2009-01-14 13:57 lvq810
    只有修改equals加上判斷  回復(fù)  更多評論
      
    # re: 我無法解釋的問題,請您一并來解釋 2009-01-14 21:43 darkmagician
    如果equals是true,hashcode必須相同。 沒必要擔(dān)心不同的object有相同的hashcode, 否則還要equals干嘛, 保證hashcode分散,只是提高效率而已。  回復(fù)  更多評論
      
    # re: 我無法解釋的問題,請您一并來解釋[未登錄] 2009-01-15 08:40 nile black
    MAP在執(zhí)行put()的時候先調(diào)用myPolSchema的hashCode()方法看當(dāng)前有沒有一樣的hashCode存在,如果沒有就直接put,有的話就調(diào)用myPolSchema的equals()方法看是否相等。
    因為你沒有實現(xiàn)hashCode(),所以用默認(rèn)的hashCode(),所以當(dāng)產(chǎn)生相同的hashCode的時候(在我機(jī)器上是運行到2058 時),因為檢查到相同的hashcode,所以調(diào)用你自己的equals(),因為GrpContNo是null,所以這時候拋 NullPointerException 。
    你機(jī)器上顯然是在1500的時候產(chǎn)生了相同了hashcode()。
    如果實現(xiàn)了hashCode(),第一次就拋NullPointerException :   回復(fù)  更多評論
      
    # re: 我無法解釋的問題,請您一并來解釋 2009-01-19 12:37 娃娃
    樓上這個師傅解釋很正確,學(xué)習(xí)了,記得考scjp的時候,有過一個題  回復(fù)  更多評論
      
    # re: 我無法解釋的問題,請您一并來解釋 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){
    //在我本地測試時當(dāng)運行大概1500左右次的時間就會拋出NullPointerException
    System.out.println("i is: " + i);
    throw ex;
    }
    }
    }

    }


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

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


    網(wǎng)站導(dǎo)航:
     
    主站蜘蛛池模板: 国产精品免费久久久久电影网| 成人无码WWW免费视频| 亚洲中文字幕视频国产| 久久99精品视免费看| 亚洲风情亚Aⅴ在线发布| 久久亚洲高清综合| 999国内精品永久免费观看| 人妻无码中文字幕免费视频蜜桃| 亚洲网址在线观看你懂的| 国产高清免费在线| 91精品国产免费网站| 国产午夜亚洲精品不卡| 亚洲成人午夜在线| 亚洲国产天堂久久综合| 日本XXX黄区免费看| 中国精品一级毛片免费播放| 亚洲无码一区二区三区| 亚洲伊人色欲综合网| 在线成人a毛片免费播放| 久久久国产精品无码免费专区| 久久精品国产亚洲AV电影网| 亚洲午夜久久久精品影院| mm1313亚洲国产精品美女| 台湾一级毛片永久免费| 两个人日本WWW免费版| 黑人粗长大战亚洲女2021国产精品成人免费视频| 国产精品亚洲精品日韩已满| 国产国产成年年人免费看片| 日韩免费一区二区三区在线播放| 丁香花在线观看免费观看图片| 亚洲第一第二第三第四第五第六 | 亚洲色精品aⅴ一区区三区| 毛片免费在线视频| 中国xxxxx高清免费看视频| 国产精品综合专区中文字幕免费播放| 亚洲xxxxxx| 亚洲一区在线观看视频| 老司机亚洲精品影院无码| 亚洲人成伊人成综合网久久久| 四虎永久成人免费| 日韩免费视频观看|