关于抽象 和 接口在java项目结构中的一些问题,有图。

mapper:接口baseMapper(公共接口),接口UserMapper继承baseMapper(其他接口);
service:接口baseService(公共接口),接口UserService继承baseService(其他接口);
serviceImpl:抽象baseServiceImpl,接口UserServiceImpl 实现 baseService,UserService

今天看到一个JAVA项目结构是这种,所有有点不明白,是否有baseService存在的必要性,如下图

图片说明


以下为2019-7-17作者补充。
经过测试后,结构重新优化,如下图:
图片说明

BaseService 为 通用接口;
BaseServiceImpl 为BaseService的实现类,BaseServiceImpl定义为抽象类。

UserService 继承了 BaseService 接口,BaseService定义为接口;

UserServiceImpl 继承了(extends)BaseServiceImpl,且 implements UserService接口;

譬如BaseService insert
UserService不继承的话

@Autowired
private UserService userService ;
userService就调用不了公共的方法了

或者
private UserServiceImpl userService;
这么用的话,是可以不要的。

不过一般都配个接口,都用接口来操作。即使这个接口可能一辈子就一个实现,咱们service还是要用一个接口,一个实现
这样更规范一点更合群一点把

嗯, 主要就是楼上说的:

如果没有这个接口继承/声明:

UserService extends BaseService{}

那么

class SomeClass{
     UserService userService;
}

在使用UserService时(比如@AutoWired注入), 虽然实现有事实上实现(继承)了BaseService的方法, 但是userService只能调用
UserService中定义的方法.

第二个原因,我的理解, 如果是spring ,aop 动态代理等, 有接口的话用JDK动态代理'更方便'