例如,用一个DatabaseRow类型表示一个数据库行(容器),用泛型Column<T>作为它的键

以下是一个简单的示例,演示如何使用泛型的Column<T>作为DatabaseRow的键,表示一个数据库行(容器):

java 复制代码
// 列定义
class Column<T> {
    private String columnName;
    private T value;

    public Column(String columnName, T value) {
        this.columnName = columnName;
        this.value = value;
    }

    public String getColumnName() {
        return columnName;
    }

    public T getValue() {
        return value;
    }
}

// 数据库行
class DatabaseRow {
    private Map<String, Column<?>> columns = new HashMap<>();

    // 添加列到数据库行
    public <T> void addColumn(Column<T> column) {
        columns.put(column.getColumnName(), column);
    }

    // 获取列的值
    public <T> T getColumnValue(String columnName, Class<T> valueType) {
        Column<?> column = columns.get(columnName);
        if (column != null && valueType.isInstance(column.getValue())) {
            return valueType.cast(column.getValue());
        }
        return null;
    }
}

public class DatabaseExample {
    public static void main(String[] args) {
        // 创建数据库行
        DatabaseRow row = new DatabaseRow();

        // 添加不同类型的列
        Column<String> nameColumn = new Column<>("Name", "John Doe");
        Column<Integer> ageColumn = new Column<>("Age", 25);
        Column<Double> salaryColumn = new Column<>("Salary", 50000.0);

        row.addColumn(nameColumn);
        row.addColumn(ageColumn);
        row.addColumn(salaryColumn);

        // 获取列的值
        String name = row.getColumnValue("Name", String.class);
        Integer age = row.getColumnValue("Age", Integer.class);
        Double salary = row.getColumnValue("Salary", Double.class);

        // 输出列的值
        System.out.println("Name: " + name);
        System.out.println("Age: " + age);
        System.out.println("Salary: " + salary);
    }
}

在这个例子中,Column<T>表示数据库行的列,具有列名和对应的值。DatabaseRow表示整个数据库行,包含了多个列。使用泛型的好处在于可以存储不同类型的列,并且在获取列的值时能够进行类型安全的检查。

通过addColumn方法,你可以向数据库行添加不同类型的列。而通过getColumnValue方法,你可以从数据库行中安全地获取列的值,并指定期望的值类型。这种设计提高了类型安全性,确保了在运行时不会出现类型错误。

相关推荐
小辰记事本4 小时前
从零读懂RoCEv2数据包构造:从WQE到线缆上的完整旅程
服务器·网络·网络协议·rdma
廿一夏5 小时前
MySql存储引擎与索引
数据库·sql·mysql
Mahir085 小时前
Spring 循环依赖深度解密:从问题本质到三级缓存源码级解析
java·后端·spring·缓存·面试·循环依赖·三级缓存
RyFit6 小时前
SpringAI 常见问题及解决方案大全
java·ai
石山代码6 小时前
C++ 内存分区 堆区
java·开发语言·c++
绝知此事6 小时前
【算法突围 01】线性结构与哈希表:后端开发的收纳术
java·数据结构·算法·面试·jdk·散列表
无风听海6 小时前
C# 隐式转换深度解析
java·开发语言·c#
lzhdim6 小时前
SQL 入门 15:SQL 事务:从 ACID 到四种常见的并发问题
数据库·sql
瀚高PG实验室7 小时前
瀚高企业版V9.1.1在pg_restore还原备份文件时提示extract函数语法问题
数据库·瀚高数据库
一只大袋鼠7 小时前
Git 进阶(二):分支管理、暂存栈、远程仓库与多人协作
java·开发语言·git