Java泛型04:自定义泛型类的使用

简介: Java泛型04:自定义泛型类的使用

实验:自定义泛型类的使用

题目:

定义个泛型类 DAO<T>,在其中定义一个 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<T> list():返回 map 中存放的所有 T 对象
public void delete(String id):删除指定 id 对象

定义一个 User 类:
该类包含:private 成员变量(int 类型) id,age;(String 类型)name。
定义一个测试类:
创建 DAO 类的对象, 分别调用其 save、get、update、list、delete 方法来操作 User 对象,
使用 Junit 单元测试类进行测试。

第一步

:o:定义个泛型类 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 对象

package com.jsm.java2;
import java.util.*;
public class DAO<T> {
    private Map<String,T> map=new HashMap<String, T>();//这里显式的赋值为null,不然调用的时候要报空指针异常

    // 保存 T 类型的对象到 Map 成员变量中
    public void save(String id,T entity){
        map.put(id,entity);
    }
    //从 map 中获取 id 对应的对象
    public T get(String id){
        T t = map.get(id);
        return t;
    }
    //替换 map 中 key 为 id 的内容,改为 entity 对象
    public void update(String id,T entity){
        if (map.containsKey(id)){//先判断是否有id为这个的对象
            map.put(id,entity);
        }else {
            System.out.println("没有id为"+id+"的元素");
        }
    }
    //返回 map 中存放的所有 T 对象
    public List<T> list(){

        //错误举例:
        /*List<T> list =(List<T>) map.values();
        return list;*/
        //用values取到的Collection去遍历然后放到List当中

        List<T> list = new ArrayList<>();
        Collection<T> values = map.values();
        //增强for循环和Iterator迭代器都可以
        for(T t :values){//遍历values,取出每一个t放到list当中
            list.add(t);
        }
        return list;
    }
    //删除指定 id 对象
    public void delete(String id){
        map.remove(id);
    }
}

第二步

:o:定义一个 User 类:
该类包含:private 成员变量(int 类型) id,age;(String 类型)name。
(这里提供了基本的get和set方法以及重写toString方法以及创建了空参和有参构造器)

package com.jsm.java2;

import java.util.Objects;

public class User {
    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 + '\'' +
                '}';
    }

    //实例化DAO的时候就认为T是User了,T是存放在Map当中了,所以User一般要提供equals方法

    @Override
    public boolean equals(Object o) {
        if (this == o) return true;
        if (o == null || getClass() != o.getClass()) return false;
        User user = (User) o;
        return id == user.id &&
                age == user.age &&
                Objects.equals(name, user.name);
    }
}

第三步

:o:定义一个测试类:
创建 DAO 类的对象, 分别调用其 save、get、update、list、delete 方法来操作 User 对象,

package com.jsm.java2;

import java.util.List;
/*
创建 DAO 类的对象, 分别调用其 save、get、update、list、delete 方
法来操作 User 对象,
 */
public class DAOTest {

    public static void main(String[] args) {
        DAO<User> userDAO = new DAO<>();
        //调用其 save方法
        userDAO.save("1000", new User(1000, 34, "金士曼"));
        userDAO.save("1001", new User(1001, 20, "Tom"));
        userDAO.save("1002", new User(1002, 17, "小明"));
        userDAO.save("1003",new User(1003, 98, "老同志"));
        //调用delete方法
        userDAO.delete("1001");
        //调用其list方法
        List<User> list = userDAO.list();
//        System.out.println(list);//直接输出也是可以的
        list.forEach(System.out::println);
        //上面代码运行结果:
        /*User{id=1002, age=17, name='小明'}
        User{id=1001, age=20, name='Tom'}
        User{id=1000, age=34, name='金士曼'}*/

        //调用其get方法
        User user = userDAO.get("1003");
        System.out.println(user);//User{id=1001, age=20, name='Tom'}

        //调用update方法
        userDAO.update("1009",new User(1003, 98, "老同志"));//没有id为1009的元素

    }
}
目录
相关文章
|
17小时前
|
Java 调度
Calendar类在Java中的应用
Calendar类在Java中的应用
|
17小时前
|
Java
Java中Integer类的应用
Java中Integer类的应用
|
2天前
|
存储 安全 Java
JAVA 泛型新篇章:编译时类型安全的新境界!
【6月更文挑战第28天】Java 泛型增强了编译时类型安全,避免运行时类型转换异常。例如,未使用泛型的代码可能因隐含的类型转换抛出`ClassCastException`。泛型允许指定容器如`List&lt;String&gt;`的元素类型,确保编译期检查。此外,泛型类如`Stack&lt;T&gt;`能适应多种类型,提高代码重用。使用泛型方法如`&lt;T&gt; void processElements(List&lt;T&gt;)`可增强方法的通用性。泛型是Java中提升可靠性和灵活性的关键工具。
|
2天前
|
Java
深入了解Java中的BigDecimal类及其方法
深入了解Java中的BigDecimal类及其方法
9 1
|
2天前
|
存储 安全 Java
JAVA泛型:类型安全,从编译时开始!
【6月更文挑战第28天】Java泛型是JDK 5引入的特性,用于在编译时实现类型安全的集合。它通过类型参数增强代码灵活性和重用性,减少错误。示例展示了泛型列表`List&lt;Integer&gt;`和`List&lt;String&gt;`如何确保元素类型正确,防止编译时类型不符。泛型提升了代码的类型安全、可读性和维护性。
|
2天前
|
存储 安全 Java
探索JAVA泛型:让代码在编译时就拥有金钟罩铁布衫!
【6月更文挑战第28天】Java泛型,自1.5版起,是代码安全性的守护者。它允许在类、接口和方法中使用类型参数,减少重复代码,提升可读性。泛型在编译时执行类型检查,防止运行时类型错误,如同给代码穿上“金钟罩铁布衫”。以Box类为例,泛型避免了显式转换,确保类型安全,让编程更加高效和无忧。
|
2天前
|
安全 Java 编译器
JAVA泛型,编译时类型安全的“秘密武器”
【6月更文挑战第28天】Java泛型是JDK 5引入的特性,用于在编译时增强类型安全和代码复用。它允许类、接口和方法使用类型参数,确保运行时类型匹配,减少了类型转换错误。例如,泛型方法`&lt;T&gt; void printArray(T[] array)`能接受任何类型数组,编译器会检查类型一致性。此外,泛型提升了代码的可读性、可维护性和与容器类的配合效率,优化整体软件质量。
|
2天前
|
存储 安全 Java
JAVA泛型:为何它是编程界的“安全卫士”?
【6月更文挑战第28天】Java泛型增强了代码复用、可读性和类型安全。它们引入类型参数,允许在编译时检查类型,防止运行时异常。例如,泛型ArrayList防止了不兼容类型的添加,而泛型方法和类减少了重复代码。示例展示了泛型类`Box&lt;T&gt;`、泛型方法`printArray&lt;T&gt;`和泛型接口`Printer&lt;T&gt;`的使用,强调了泛型在确保类型安全和灵活性方面的价值。
|
2天前
|
Java 数据安全/隐私保护
Java基础手册二(类和对象 对象创建和使用 面向对象封装性 构造方法与参数传递 this关键字 static关键字 继承 多态 方法覆盖 final关键字 访问控制权限修饰符)
Java基础手册二(类和对象 对象创建和使用 面向对象封装性 构造方法与参数传递 this关键字 static关键字 继承 多态 方法覆盖 final关键字 访问控制权限修饰符)
9 0
|
2天前
|
存储 安全 Java
Java泛型:深度解析编译时类型安全的核心机制
【6月更文挑战第28天】Java泛型自JDK 1.5起增强了代码安全与复用。它们允许类、接口和方法使用类型参数,如`&lt;T&gt;`在`Box&lt;T&gt;`中。泛型确保编译时类型安全,例如`List&lt;String&gt;`防止了运行时ClassCastException。尽管运行时存在类型擦除,编译时检查仍保障安全。理解泛型核心机制对于优化Java编程至关重要。