Java基础篇泛型补充

CSDN话题挑战赛第1期
活动详情地址:https://marketing.csdn.net/p/bb5081d88a77db8d6ef45bb7b6ef3d7f
参赛话题:Java学习记录
话题描述:可以记录一下平时学习Java中的一些知识点、心得、例题、常见的问题解决

说明

泛型重要的知识点就在于对集合中泛型的使用,以及在开发时中实现对数据库的操作,其他的细小知识点理解即可,不必深究

1.1 泛型在继承上的使用

说明
主要测试泛型类被其他的类继承之后的不同情形
Order类

public class Order <T>{

    private String orderName;
    private int orderAge;

    T orderT;

    public Order() {
    }

    public Order(String orderName, int orderAge, T orderT) {
        this.orderName = orderName;
        this.orderAge = orderAge;
        this.orderT = orderT;
    }

    public String getOrderName() {
        return orderName;
    }

    public void setOrderName(String orderName) {
        this.orderName = orderName;
    }

    public int getOrderAge() {
        return orderAge;
    }

    public void setOrderAge(int orderAge) {
        this.orderAge = orderAge;
    }

    public T getOrderT() {
        return orderT;
    }

    public void setOrderT(T orderT) {
        this.orderT = orderT;
    }

    //静态方法中不能使用类的泛型,静态方法的加载是在类的创建的时候,但是泛型的指定是在实例化的时候
//    public static void show(T orderT){
//        System.out.println(orderT);
//    }

    public void test1(){
    }

    //泛型方法:在方法中出现了泛型的结构,泛型参数与类的泛型参数没有任何关系
    //换句话说:泛型方法所属的类是不是泛型类都没有关系
    //在返回值类型前面加一个<E>表示E是一个泛型
    //泛型方法,可以声明为静态的。原因为:泛型参数是在调用方法时确定的,并非在实例化类时确定
    public <E> List<E> copyFromArrayToList(E[] arr){

        ArrayList<E> list = new ArrayList<>();
        for (E e: arr){
            list.add(e);
        }
        return list;
    }
}

sunOrder类
指名泛型的类型,此时subOrder已经不是一个泛型类

public class subOrder extends Order<Integer>{
    public subOrder() {
    }

    public subOrder(String orderName, int orderAge, Integer orderT) {
        super(orderName, orderAge, orderT);

    }
}

subOrder2类

public class subOrder2<T> extends Order{
}

测试类

public class GenericTest1 {

    @Test
    public void test1(){
        //在Order内定义泛型的属性之后,在进行实例化的时候要指明泛型的类型,
        Order<String> order = new Order<>("李华",25,"2020-05-16");

        //创建一个子类,在继承时直接声明泛型的类型,这样来说子类就不算是泛型类,把泛型的属性已经规定了
        subOrder order1 = new subOrder("李华",15,16);

        //创建一个子类,在继承时没有直接声明泛型的类型,这样来说子类就是泛型类,需要在实例化的时候声明
        //subOrder类中也要将类修改为泛型类才可以
        subOrder2<String> order2 = new subOrder2();

        //静态方法中不能使用类的泛型,静态方法的加载是在类的创建的时候,但是泛型的指定是在实例化的时候
        //    public static void show(T orderT){
//        System.out.println(orderT);
//    }
        }

        @Test
        public void test2(){
            //泛型方法:在方法中出现了泛型的结构,泛型参数与类的泛型参数没有任何关系
            //    //换句话说:泛型方法所属的类是不是泛型类都没有关系
            //    //在返回值类型前面加一个<E>表示E是一个泛型
            //    public <E> List<E> copyFromArrayToList(E[] arr){
            //
            //        ArrayList<E> list = new ArrayList<>();
            //        for (E e: arr){
            //            list.add(e);
            //        }
            //        return list;
            //    }

            //测试泛型方法
            Order<String> order = new Order<>();
            Integer[] arr = new Integer[]{1,2,3,4,5,6};
            //泛型在调用的时候指明了泛型的类型
            List<Integer> list = order.copyFromArrayToList(arr);
            System.out.println(list);
        }
        //泛型数组的创建
//        E[] e = (E[]) new Object[15];
}

1.2 泛型在开发中的使用举例

模拟实现对数据的增删改查功能
DAO类

public class DAO<T> {//表的共性操作的DAO
    //添加一条数据
    public  void add(T t){

    }

    //删除一条记录
    public boolean delete(T t){
        return false;
    }
    //修改一条数据
    public void update(int index,T t){

    }
    //查询一条数据
    public T getIndex(int index){
        return null;
    }

    //查询多条记录
    public List<T> getForList(int index){
        return null;
    }

    //泛型方法
    public <E> E getIndex(){
        return null;
    }
}

Customer类

public class Customer {

}

CustomerDAO类

public class CustomerDAO extends DAO<Customer>{//只操作客户表
}

Student类

public class Student {
}

StudentDAO类
操作学生类

public class StudentDAO extends DAO<Student>{//只操作学生表

}

测试类

public class DAOTest {
    @Test
    public void test1(){

        CustomerDAO dao = new CustomerDAO();
        dao.add(new Customer());
        List<Customer> list = dao.getForList(10);

        StudentDAO dao1 = new StudentDAO();
        dao1.add(new Student());
        //获取编号在10以下的写生
        List<Student> list1 = dao1.getForList(10);
    }
}

1.3 泛型使用示例

理解这个最重要
题目说明
定义个泛型类 DAO,在其中定义一个 Map 成员变量,Map 的键为 String 类型,值为 T 类型。
分别创建以下方法:
public void save(String id,T entity): 保存 T 类型的对象到 Map 成员变量中
public T get(String id):从 map 中获取 id 对应的对象
public void update(String id,T entity):替换 map 中 key 为 id 的内容,改为 entity 对象
public List list():返回 map 中存放的所有 T 对象
public void delete(String id):删除指定 id 对象
定义一个 User 类:
该类包含:private 成员变量(int 类型) id,age;(String 类型)name。
定义一个测试类:
创建 DAO 类的对象, 分别调用其 save、get、update、list、delete 方
法来操作 User 对象,
使用 Junit 单元测试类进行测试

DAO类

public class DAO<T>{

    private Map<String,T> map = new HashMap<>();

    //保存 T 类型的对象到 Map 成员
    public void save(String id,T entity) {
        map.put(id, entity);
    }

    //从 map 中获取 id 对应的对象
    public T get(String id) {
        return map.get(id);
    }

    //替换 map 中 key 为 id 的内容,改为 entity 对象
    public void update(String id,T entity){
        if (map.containsKey(id)){//判断此id对应的键值对对象是否存在
            map.put(id, entity);
        }
    }

    //:返回 map 中存放的所有 T 对象
    public List<T> list(){

        //思想:首先得到values对应的集合,再利用迭代器或者增强for将内容装到list集合中
        //返回的value 是在Collection集合中,要向下转(强转是不可以的,父类不能赋给子类)

        Collection<T> values = map.values();
        Iterator<T> iterator = values.iterator();
        List<T> list = new ArrayList<>();
        while (iterator.hasNext()){
            T value = iterator.next();
            list.add(value);
        }
        return list;
    }

    //:删除指定 id 对象
    public void delete(String id){

        map.remove(id);
    }
}

User类

public class User {
    //该类包含:private 成员变量(int 类型) id,age;(String 类型)name。
    private int id;
    private int age;
    private String name;

    public User() {
    }

    public User(int id, int age, String name) {
        this.id = id;
        this.age = age;
        this.name = name;
    }

    public int getId() {
        return id;
    }

    public void setId(int id) {
        this.id = id;
    }

    public int getAge() {
        return age;
    }

    public void setAge(int age) {
        this.age = age;
    }

    public String getName() {
        return name;
    }

    public void setName(String name) {
        this.name = name;
    }

    @Override
    public String toString() {
        return "User{" +
                "id=" + id +
                ", age=" + age +
                ", name='" + name + '\'' +
                '}';
    }

    @Override
    public boolean equals(Object o) {
        if (this == o) return true;
        if (o == null || getClass() != o.getClass()) return false;

        User user = (User) o;

        if (id != user.id) return false;
        if (age != user.age) return false;
        return name != null ? name.equals(user.name) : user.name == null;
    }

    @Override
    public int hashCode() {
        int result = id;
        result = 31 * result + age;
        result = 31 * result + (name != null ? name.hashCode() : 0);
        return result;
    }
}

DAOTest类:

public class DAOTest {
    public static void main(String[] args) {

        DAO<User> dao = new DAO<>();

        dao.save("1001",new User(1001,25,"Jerry"));
        dao.save("1002",new User(1002,24,"Jack"));
        dao.save("1003",new User(1003,23,"Jane"));

        User user = dao.get("1003");
        System.out.println(user);

        System.out.println("****************");

        dao.update("1003",new User(1003,22,"Ken"));

        List<User> list = dao.list();
        System.out.println(list);

        System.out.println("**************");
        dao.delete("1003");
        List<User> list1 = dao.list();
        System.out.println(list1);
    }
}
  • 15
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 7
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 7
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

皮皮皮皮皮皮皮卡乒

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值