以下是一个简单的示例,演示如何使用泛型的Column<T>
作为DatabaseRow
的键,表示一个数据库行(容器):
// 列定义
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
方法,你可以从数据库行中安全地获取列的值,并指定期望的值类型。这种设计提高了类型安全性,确保了在运行时不会出现类型错误。