簡體   English   中英

添加到HashSet時,空指針異常

[英]null pointer exception when adding to HashSet

即使我已經初始化了HashSet,當我嘗試向其添加元素時,也會出現空指針異常。

@OneToMany(cascade = { CascadeType.ALL }, fetch = FetchType.LAZY, mappedBy = "artikal")
private Set<Cenovnik> cene = new HashSet<Cenovnik>();

public Set<Cenovnik> getCene() {
    if (cene == null)
        this.cene = new HashSet<Cenovnik>();

    return cene;
}

我這樣使用它:

Cenovnik cenovnik = new Cenovnik(date, null, cena);
Artikal artikal = artikalDao.findById(id);
Cenovnik stari = artikalDao.cena(id);

if (stari != null) {
    stari.setKrajkVazenja(date);
    cenovnikDao.merge(stari);
}

cenovnik.setArtikal(artikal);
artikal.getCene().add(cenovnik); //error!
cenovnikDao.persist(cenovnik);
artikalDao.merge(artikal);

因此,當我嘗試將cenovnik添加到artikal.getCene時,我已經檢查了錯誤,由於某種原因,getCene似乎是問題。 這是Cenovnik課

public class Cenovnik implements Serializable{

/**
 * 
 */
private static final long serialVersionUID = -1436274372349853081L;
@Id
@GeneratedValue(strategy = IDENTITY)
@Column(name = "cenovnik_id", unique = true, nullable = false)
private Integer id;
  ...   

@ManyToOne
@JoinColumn(name="artikal_id", referencedColumnName="artikal_id")
private Artikal artikal;    

public Artikal getArtikal() {
    return artikal;
}

public void setArtikal(Artikal artikal) {
    this.artikal = artikal;
}
    ...
public int hashCode() {
    final int prime = 31;
    int result = 1;
    result = prime * result + ((id == null) ? 0 : id.hashCode());
    return result;
}

這是完整的堆棧跟蹤:

java.lang.NullPointerException:

        rs.ac.uns.acs.ism.server.servlet.DodajCenuArtiklaController.doGet(DodajCenuArtiklaController.java:78)

        rs.ac.uns.acs.ism.server.servlet.DodajCenuArtiklaController.doPost(DodajCenuArtiklaController.java:109)

        javax.servlet.http.HttpServlet.service(HttpServlet.java:641)

        javax.servlet.http.HttpServlet.service(HttpServlet.java:722)

        org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:305)

        org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:210)

        org.apache.catalina.core.ApplicationDispatcher.invoke(ApplicationDispatcher.java:749)

        org.apache.catalina.core.ApplicationDispatcher.processRequest(ApplicationDispatcher.java:487)

        org.apache.catalina.core.ApplicationDispatcher.doForward(ApplicationDispatcher.java:412)

        org.apache.catalina.core.ApplicationDispatcher.forward(ApplicationDispatcher.java:339)

        rs.ac.uns.acs.ism.server.servlet.DodajArtikalController.doGet(DodajArtikalController.java:72)

        rs.ac.uns.acs.ism.server.servlet.DodajArtikalController.doPost(DodajArtikalController.java:94)

        javax.servlet.http.HttpServlet.service(HttpServlet.java:641)

        javax.servlet.http.HttpServlet.service(HttpServlet.java:722)

        org.apache.catalina.core.ApplicationFilterChain.internalDoFilter(ApplicationFilterChain.java:305)

        org.apache.catalina.core.ApplicationFilterChain.doFilter(ApplicationFilterChain.java:210)

        org.apache.catalina.core.StandardWrapperValve.invoke(StandardWrapperValve.java:222)

        org.apache.catalina.core.StandardContextValve.invoke(StandardContextValve.java:123)

        org.apache.tomee.catalina.OpenEJBValve.invoke(OpenEJBValve.java:45)

        org.apache.catalina.authenticator.AuthenticatorBase.invoke(AuthenticatorBase.java:472)

        org.apache.catalina.core.StandardHostValve.invoke(StandardHostValve.java:168)

        org.apache.catalina.valves.ErrorReportValve.invoke(ErrorReportValve.java:99)

        org.apache.catalina.valves.AccessLogValve.invoke(AccessLogValve.java:929)

        org.apache.catalina.core.StandardEngineValve.invoke(StandardEngineValve.java:118)

        org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:407)

        org.apache.coyote.http11.AbstractHttp11Processor.process(AbstractHttp11Processor.java:1002)

        org.apache.coyote.AbstractProtocol$AbstractConnectionHandler.process(AbstractProtocol.java:585)

        org.apache.tomcat.util.net.JIoEndpoint$SocketProcessor.run(JIoEndpoint.java:310)

        java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1145)

        java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:615)

        java.lang.Thread.run(Thread.java:745)

這是equals方法:

    @Override
public boolean equals(Object obj) {
    if (this == obj)
        return true;
    if (obj == null)
        return false;
    if (getClass() != obj.getClass())
        return false;
    Cenovnik other = (Cenovnik) obj;
    if (id == null) {
        if (other.id != null)
            return false;
    } else if (!id.equals(other.id))
        return false;
    return true;
}

您正在從數據源獲取一條記錄,然后在不檢查其是否為空的情況下使用它。

嘗試

Artikal artikal = artikalDao.findById(id);

if (artikal != null) {
   artikal.getCene().add(cenovnik);
}  else 
{
   // throw something
}

如果artikal為null,則為另一種情況。 然后像這樣做一個空檢查

 if(artikal != null) {
    artikal.getCene().add(cenovnik);
 }

嘗試進行此調試以分解getCene()並將其添加到兩行中,並添加一些打印語句,以供您使用某些記錄器時使用。 這將有助於了解發生了什么

       if(artikal != null) {
            System.out.println("artikal is not null");
            Set<Cenovnik> cenovniks= artikal.getCene();

            if(cenovniks != null) {
                System.out.println("cenovniks set is not null");
                cenovniks.add(cenovnik);
                System.out.println("Added cenovnik to set");
            } else {
                // Handle null cenovniks as appropriate to your application
                System.out.println("cenovniks set is null");
            }
        } else {
            System.out.println("artikal is null");
            // Handle null artikal as appropriate to your application
        }

除此以外

請注意,這僅適用於添加到哈希集時的哈希集的add()方法

將對象添加到集合會引發空指針異常的原因是:

要添加到哈希集的對象的屬性之一用於計算對象的哈希碼。 在計算哈希碼期間,此屬性將引發空指針異常。

它可以是日期或其他屬性。 檢查該類的哈希碼實現,在哈希碼方法中放置一個斷點,以查看是否拋出該nullpointer。

更新1查看hascode和equals方法似乎沒有引起問題。

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM