问题说明:
使用Mybatis框架的时候,想封装一个底层JDBC控制器,用于提供和Mybatis交互的增删改查接口(公用的接口),但由于公用的查询方法可能是用户自定义的任意一个和表对应的实体类型,所以要考虑怎么样给调用者返回正确的返回值类型,不需要调用者自己强转型的动作。例如:返回Object类型给调用者,那么调用者就需要拿到这个Object类型进行强转型为表对应的实体类型。
解决方案:
java提供的泛型 T 是非常实用强大的一个特性,我们可以考虑将方法的返回值设为泛型。泛型是在运行时才确定真正的类型,而不是在编译时。例子
1. 服务提供者函数:
//通过<T>声明告诉JVM返回值定义一个泛型 T
//这里T只是个占位符的效果,26个字母随便写哪个字母都可以,但一定要是和< >里面相同的字母
public <T> T findList(String sqlID,Map<String,Object> params) {
//映射sql的标识字符串
String statement = "com.mybatis.mapping.userMapper."+sqlID;
return (T) this.session.selectList(statement, params);
}
2. 服务调用者函数:
//这里接收的类型声明直接写真实的类型就可以,无需强制转换
List<SubsHis> list = jdbc.findList("getSubsHisList", map);