Java中的泛型

泛型是一种类型参数。将数据的类型,当做一个参数。


1. 泛型的作用

  • 在创建集合对象的时候,限定集合存储元素的类型
  • 在编译的时候,就进行类型检查;

2. 泛型的使用规则

  • 如果不指定泛型,默认是Object类型
  • 泛型擦除:泛型应用于代码编译期,程序运行的后,泛型就被擦除了。即运行期,泛型被擦除。
  • 同时指定多个泛型<E1,E2,E3,....>
  • 静态方法中,不能使用泛型类或泛型接口。
  • 泛型方法,可以是静态的。 因为方法被调用时,才确定泛型参数的类型
  • 泛型数组:java E[] elements = (E[])new Object[capacity];

3. 泛型的分类

  • 泛型类
    类中的某个属性,在定义的时候,不能确定是什么类型,可以使用泛型表示该属性的类型
  • 泛型接口
    接口中的方法参数类型 或 返回值类型,不确定的时候,使用泛型替代
  • 泛型方法
    类上面没有泛型,但是方法上指定了泛型。一般用于工具类,不能实例化对象
    方法的参数类型或返回值类型,不能确定的时候,使用泛型代替


4. 通配符的使用

通配符用于指定泛型的范围(上限和下限)

  • ? 任意类型

    List<?>:只能写入null值。

  • <? super 类型>:当前类型或当前类型的父类型

  • <? extends 类型>:当前类型或当前类型的子类


5. 应用实例

泛型接口的使用

//泛型接口
public interface MyCollection<T> {
    void add(T t);
}

//情况1:子类定义是,直接指定泛型的具体类型
public class MyCollectionImpl01 implements MyCollection<Integer> {
    @Override
    public void add(Integer integer) {

    }
}

//情况2:子类是一个泛型类
public class MyCollectionImpl02<T> implements MyCollection<T> {
    @Override
    public void add(T t) {

    }
}

泛型方法的使用

/**
 * 打印不同类型的集合
 */
public <E> void printAll(E e){
    if(e instanceof Collection){
        ((Collection) e).forEach(System.out::println);
    }else if( e instanceof Map){
        Set set = ((Map) e).entrySet();
        Iterator iterator = set.iterator();
        while(iterator.hasNext()){
            Map.Entry next = (Map.Entry) iterator.next();
            System.out.println(next.getKey()+" "+next.getValue());
        }
    }else{
        System.out.println(e);
    }
}

查询所有的记录

引入依赖

<dependency>
    <groupId>mysql</groupId>
    <artifactId>mysql-connector-java</artifactId>
    <version>5.1.3</version>
</dependency>


JavaBean实体类

public class Book{
    private Integer id;
    private  String bookName;
    private  String author;
    private  Double price;


JDBC 工具类

/**
 * 工具类:获取MySQL数据库连接
 */
public class JDBCUtil {
    private static final String DRIVER = "com.mysql.jdbc.Driver";

    //数据库连接参数
    private static final String URL = "jdbc:mysql://localhost/db_day525";
    private static final String NAME = "root";
    private static final String PASSWORD = "admin";

    //注册驱动(仅注册1次)
    static {
        try {
            Class.forName(DRIVER);
        } catch (ClassNotFoundException e) {
            e.printStackTrace();
        }
    }

    //数据库连接
    public static Connection getConnection() {
        try {
            return DriverManager.getConnection(URL, NAME, PASSWORD);
        } catch (SQLException e) {
            e.printStackTrace();
        }
        return null;
    }

    //释放资源
    public static void close(Connection conn, Statement stmt) {
        close(conn, stmt, null);//方法重用
    }
    public static void close(Connection conn, Statement stmt, ResultSet rs) {
        try {
            if (rs != null) {
                rs.close();
            }
        } catch (SQLException throwables) {
            throwables.printStackTrace();
        }
        try {
            if (stmt != null) {
                stmt.close();
            }
        } catch (SQLException throwables) {
            throwables.printStackTrace();
        }
        try {
            if (conn != null) {
                conn.close();
            }
        } catch (SQLException throwables) {
            throwables.printStackTrace();
        }
    }
}


Dao层
泛型接口

/**
 * Dao层泛型接口:通用的CURD方法
 */
public interface Dao<T> {
    /**
     * 添加一条记录
     * @param t
     */
    void insert(T t);
    
    /**
     * 删除一条记录
     * @param t
     */
    void delete(T t);
    

    /**
     *查询所有数据
     */
    List<T> selectAll() throws SQLException;
    

    /**
     * 查询一个数据:根据id
     */
    T select(int index);
    

    /**
     * 修改一条记录:根据id
     */
    void update(int index, T t);
}

实现类

public class BookDaoImpl implements Dao<Book> {
    Connection conn = JDBCUtil.getConnection();

    @Override
    public List<Book> selectAll() throws SQLException {
        List<Book> list = new ArrayList<>();
        String sql = "select book_id as id,book_name as bookName,author,price from t_book";

        PreparedStatement preStatement = conn.prepareStatement(sql);
        ResultSet resultSet = preStatement.executeQuery();

        while(resultSet.next()){
            int bookId = resultSet.getInt(1);
            String bookName = resultSet.getString(2);
            String author = resultSet.getString(3);
            Double price = resultSet.getDouble(4);

            list.add(new Book(bookId,bookName,author,price));
        }
        return list;
    }
    
    @Override
    public void insert(Book book) {}
    @Override
    public void delete(Book book) {}
    @Override
    public Book select(int index) {return null;}
    @Override
    public void update(int index, Book book) {}
}


测试

public static void main(String[] args) throws SQLException {
    Dao dao = new BookDaoImpl();
    List list = dao.selectAll();

    list.forEach(System.out::print);
}