我有一个方法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));
}
//............
答案 0 :(得分:0)
在有状态EJB中扩展线程通常是一个坏主意,因为容器可能随时passivated。您还可以考虑群集和SFSB复制 - 您的EJB可能被序列化到另一台机器,并且Thread不适用于此(它不是Serializable)。
如果在em.persists(...)中抛出了NullPointerException,那么你就错过了“em”引用。最有可能的是,您尝试@Inject EntityManager到EntryConfig实例,而不是由容器管理。如果你想在容器之外重用这个类,你需要手动设置EntityManager(第一部分仍然很难应用 - 你应该重新设计整个组件)。