在单独的线程中调用方法会导致NullPointerException

时间:2013-03-24 16:13:09

标签: java jpa ejb

我有一个方法loadDatabase()。该方法本身就很完美。

当我创建一个单独的线程并调用方法loadDatabase()时,我得到如下所示的错误。 在主线程上它工作正常。

有什么想法吗? 注意:值causecode,eventid和description不为null,因为我已将它们打印到屏幕上。

错误

15:59:58,693 INFO  [stdout] (Thread-64) Importing EcentCauseSheet
15:59:58,694 INFO  [stdout] (Thread-64) Cause Code is 0
15:59:58,694 INFO  [stdout] (Thread-64) Event Id  4097
15:59:58,695 INFO  [stdout] (Thread-64) Description is RRC CONN SETUP-SUCCESS
15:59:58,703 ERROR [stderr] (Thread-64) Exception in thread "Thread-64" java.lang.NullPointerException
15:59:58,704 ERROR [stderr] (Thread-64)     at com.testapp.service.EntryConfig.loadDatabase(EntryConfig.java:131)
15:59:58,704 ERROR [stderr] (Thread-64)     at com.testapp.service.EntryConfig.HelloWorld(EntryConfig.java:48)
15:59:58,704 ERROR [stderr] (Thread-64)     at com.testapp.service.EntryConfig.run(EntryConfig.java:39)

类的Java代码

@Stateful
@LocalBean
public class EntryConfig extends Thread implements TableDao {

    @Inject
    private EntityManager em;
//.......

线程的Java代码

@Override
       public void run()
       {
        HelloWorld();

       }

public void HelloWorld()     {

    try {
        loadDatabase();         

    } catch (InterruptedException e) {
        // TODO Auto-generated catch block
        e.printStackTrace();
    }

}

loadDatabase()的Java代码

public void loadDatabase()
    {
        InputStream inp = null;
        System.out.println("Eureka Kind of .....");
        try {   
            inp = new FileInputStream("/home/ubuntu/Downloads/test.xls");  

        } catch (Exception ex) {
        } finally {
            try {
                wb = WorkbookFactory.create(inp);
            } catch (InvalidFormatException e) {

                e.printStackTrace();
            } catch (IOException e) {

                e.printStackTrace();
            }

            Sheet eventCauseTableSheet = wb.getSheetAt(1);

            for (int i = 1; i <= eventCauseTableSheet.getLastRowNum(); i++) {
                System.out.println("Importing EcentCauseSheet");

                row = eventCauseTableSheet.getRow(i);                                       
                int causeCode = (int)(row.getCell(0).getNumericCellValue());                                         
                int eventId = (int)(row.getCell(1).getNumericCellValue());                      
                String description = row.getCell(2).toString();

                System.out.println("Cause Code is " + causeCode);
                System.out.println("Event Id  " + eventId);             
                System.out.println("Description is " + description);

                EventCauseTable eventCauseTable = new EventCauseTable(causeCode,eventId,description);               
                em.persist(eventCauseTable);
                System.out.println("Persisted EventCauseSheet row" + (i+1));

            }

//............

1 个答案:

答案 0 :(得分:0)

在有状态EJB中扩展线程通常是一个坏主意,因为容器可能随时passivated。您还可以考虑群集和SFSB复制 - 您的EJB可能被序列化到另一台机器,并且Thread不适用于此(它不是Serializable)。

如果在em.persists(...)中抛出了NullPointerException,那么你就错过了“em”引用。最有可能的是,您尝试@Inject EntityManager到EntryConfig实例,而不是由容器管理。如果你想在容器之外重用这个类,你需要手动设置EntityManager(第一部分仍然很难应用 - 你应该重新设计整个组件)。