这可能有点笼统,如果太过分,我深表歉意。它与大学课程的作业有关,因此希望专注于我对主题的理解,而不是答案应该是什么。 据我了解情况: 我有一个名为pet的父类,以及两个名为Dog and Cat的子类。UML 类图指定 Pet 包含createPet()
、updatePet()
和petCheckIn()
的方法。petCheckIn()
需要能够创建对象(如果尚未创建(,如果已创建(,则更新一个对象。
这两个子类包含默认构造函数,以及其属性的 setter 和 getter,但没有特定于它们的其他内容。
我不相信会有需要宠物物品的情况,因为托运的宠物总是狗或猫。如果构造函数不是由子类继承的,而是方法继承的,并且严格来说createPet()
不是构造函数,那么如果设计正确,继承的方法可以执行构造函数吗?我觉得实现应该是这样的(不关心确切的语法,因为我对这里可以做什么和不能做什么的理解(:
我的伪代码:
Execute Dog/Cat inherited petCheckIn()
IF new pet THEN
Execute Dog/Cat inherited createPet()
ELSE
Execute Dog/Cat inherited updatePet()
这是一个入门级编程类,所以我无法想象实现会非常复杂。 可能我误解了某些东西/过于复杂。
无论如何,感谢您的时间。
编辑: 真的很抱歉,我从来没有@Karam和@Chung回复你。生活有时就像货运列车一样,哈哈。指定另一个类超出了赋值的范围(尽管我想知道的大部分内容似乎也是如此(,没有指定关于签名的内容(这是 methodName + 它的参数正确吗?最终,我相信很大程度上取决于整个程序如何实现这些课程,而整个程序没有详细介绍。我可以非常自信地说,我只是在问超出课程计划那个阶段意图的问题。我最终在超类中使用了一个参数化构造函数,在子类中使用了另一个参数化构造函数,它将超类字段的参数传递给超类构造函数,然后初始化子类特定字段。Karam,我从来没有真正定义过调用构造函数的方法,也无法自学设计模式,但我的一个亲戚也提到了一个抽象工厂。我说这可能是处理它的最佳方式。不幸的是,我现在没有更多时间深入研究这个问题,所以我称它很好。
不能告诉你们我有多感激你愿意帮助。
狗.java构造函数:
//Overloaded Constructor that passes parameters to Superclass
constructor.
//TODO: Reconsider which fields need a parameter and which can be set to
default at this point in the program.
//TODO: Verify that not passing an argument for catSpace will default to
-1.
//FIXME: Is dogSpaceNBR known at this point in program?
public Dog(int dogSpaceNBRInput, double dogWeightInput, boolean
groomingInput, String petTypeInput, String petNameInput, int petAgeInput,
int dogSpaceInput, int catSpaceInput, int daysStayInput, double
amountDueInput) {
// Passes arguments common to all pet subclasses to superclass
constructor.
super(petTypeInput, petNameInput, petAgeInput, dogSpaceInput,
catSpaceInput, daysStayInput, amountDueInput);
//Dog specific variables
dogSpaceNbr = dogSpaceNBRInput;
dogWeight = dogWeightInput;
grooming = groomingInput;
}
如果我很好地理解您的问题,您希望能够仅使用方法根据子类创建宠物的不同实例
有一种设计模式叫做抽象工厂,它用于以具体的方式忽略不同方法的创建
例:
你有包含方法class Pet
(它应该是抽象的createPet() {}
在你的子卡斯中,你必须简单地重新定义方法createPet() { return new Dog() ; /* or */ return new Cat() ;}
这可以帮助您在创建新子句时重新定义方法而不更改原始类,这不仅适用于方法createPet()
,也适用于您的所有方法