我有一个我们称之为Vehicle的抽象类。柴油、电动和燃气类扩展了车辆。这 3 个类有自己的方法和变量,以及它们从Vehicle继承的内容。
我想将Diesel、Electric和Gas对象中的变量放入数据库中的同一个表中。从Electric对象创建的记录只会有几个空列,其中没有与Diesel对象相同的变量,等等。
我想创建插入行、更新行和检索行的方法,所有这些方法都接受来自这些类的对象作为参数。
我正在寻找这个问题的最佳解决方案,因为我认为我不知道它是什么。到目前为止,我能想到一些解决方案,但我不喜欢其中任何一个:
创建以下每个方法中的 4 个:插入、更新、删除和检索/选择。这将导致大量重复代码。
public void AddVehicle(Diesel diesel) public void AddVehicle(Electric electric) public void AddVehicle(Gas gas) public Electric ViewVehicles() public Diesel ViewVehicle() public Gas ViewVehicle() public void RemoveVehicle(Diesel diesel) public void RemoveVehicle(Electric electric) public void RemoveVehicle(Gas gas) public void UpdateVehicle(Diesel diesel) public void UpdateVehicle(Electric electric) public void UpdateVehicle(Gas gas)
创建每个方法以便它可以接受任何对象:(而不是采用任何对象,有没有办法指定它可以采用的对象列表,但仍然只采用其中一个?即。public void AddVehicle(Dieseldiesel | | 电电 || 气气) )
public void AddVehicle(Object vehicle) public Object ViewVehicle(Object vehicle) public void RemoveVehicle(Object vehicle) public void UpdateVehicle(Object vehicle)
创建一个“主”类,该类可以包含任何类(柴油、电力或燃气),然后将其传递到插入/更新/查看/删除方法中。(将插入/更新/查看方法设置为接受此“主”类作为参数。)“主”类的不完整构造函数:
public MasterVehicle(Diesel diesel) public MasterVehicle(Electric electric) public MasterVehicle(Gas gas)
其他一些适当的、更清洁的、更有意义的解决方案。
但是#4可能是什么?