系统调用Service某个方法的时候,报错空指针异常
java.lang.NullPointerException: null
打印的栈信息确实是调用这个方法的时候报错,但奇怪的是,方法里面的第一行日志都没有打印,证明是没有进入这个方法。
processSopRuleScope(Dto dto, List<Entity> entities,long snowflakeId, long userId, long tenantId){
log.info("XXX")
}
初步怀疑是因为事务+this调用,导致找不到本类中的方法,但是之前没有遇到过这种问题,试着删除了方法前的this,还是报错。
this.processSopRuleScope(dto, entities, snowflakeId, userId, tenantId, 1);
然后就盯着这行代码看问题,一直怀疑是这个方法问题,但是本方法也不会再次注入对吧,如果是其他类的方法,还可能是注入对象实例的问题,但是这个明显是本类里面的本地方法。
后来灵光一闪,发现userId在上面定义的时候,是个Long包装类,从userDto.getUserId() 这样获取的,这个可能是空,processSopRuleScope方法里面接收的时候是个long,这时候就要自动拆箱,但是Long userId是个null, 所以就报空指针异常了。。。。。。
解决。