Spring容器中遇到的NullPointerException异常

今天遇到了一个NullPointerException,报错的代码行如下:

List list =adminService.searchByObjectId(objectId);

报错信息如下:

java.lang.NullPointerException
	at net.gddx.door.service.Sample.messageArrived(Sample.java:220)
	at org.eclipse.paho.client.mqttv3.internal.CommsCallback.deliverMessage(CommsCallback.java:475)
	at org.eclipse.paho.client.mqttv3.internal.CommsCallback.handleMessage(CommsCallback.java:379)
	at org.eclipse.paho.client.mqttv3.internal.CommsCallback.run(CommsCallback.java:183)
	at java.lang.Thread.run(Unknown Source)

报错信息指向为上述的代码行,但是我用JUnit测试adminService.searchByObjectId(objectId)这个方法是没有错的,能够拿到正确的信息,所以绝对不是方法的问题。

十分奇怪的是,经过多次测试,发现执行这个代码的时候根本就没有进入adminService.searchByObjectId(objectId)方法中就直接报了空指针异常(我在方法的第一行输出了一行字符串,可是执行方法的时候控制台中根本就没有显示,说明没有进入该方法),这就说明为空的是adminService。

可是adminService我是采用Spring的@Autowired注释自动加载的,代码如下:

@Autowired
private AdminService adminService

无法理解为什么adminService为空,但还是改成了了直接声明adminService而不采用自动注入的方法,修改后代码如下:

AdminService adminService = new AdminService();
List list =adminService.searchByObjectId(objectId);

结果就成功了。

 

再整理下:

报错代码行的那个类(Sample 类)被我添加了Spring的@Service注解

AdminService 类 也被我添加了@Service注解

我在Sample 类中 使用@Autowired注解自动加载了AdminService类,并且调用了其中的方法

声明的adminService执行时报错NullPointerException

解决方法为不使用@Autowired注解,该为直接声明:AdminService adminService = new AdminService();

 

原因猜测与Spring容器的加载顺序有关,但又说不清楚,有大神可以帮忙解释一下吗?

你可能感兴趣的:(BUG)