我今天早些时候问了一个类似的问题,但现在我被告知要求已经改变了。
我有3个课程 - Product
,ProductOffering
(PO)和ProductOfferingLists
(POL)。产品包含PO,PO包含POL。所有这些类都扩展了一个名为CMS的抽象类。
我想将PO附加到P,将POL附加到PO,但我正在寻找一种可重用的方法,因为逻辑是相同的,除了类名。
不幸的是,我的测试人员类需要两个方法,层次结构类需要强制转换来完成抽象的CMS合同。
这让我疯了。我怎样才能使这个更可重复使用,所以我没有多种方法和铸造?
package puzzler;
import java.util.ArrayList;
import java.util.List;
public class Tester {
public static void main(String[] args) {
Product p = new Product();
PO pa = new PO();
POL po = new POL();
List<PO> lpa = new ArrayList<PO>();
List<POL> lpo = new ArrayList<POL>();
attachChildToParent(lpa, p);
attachChildToParent(lpo, pa);
}
static void attachChildToParent(List<PO> listChild, Product parent) {
for (PO po : listChild) {
parent.attach(po);
}
}
static void attachChildToParent(List<POL> listChild, PO parent) {
for (POL po : listChild) {
parent.attach(po);
}
}
}
CMS类:
package puzzler;
abstract class CMS {
abstract void attach(CMS childNode);
}
产品类 - 拥有PO的层次结构的顶部:
package puzzler;
import java.util.List;
public class Product extends CMS {
List<PO> lpo;
public List<PO> getLpo() {
return lpo;
}
public void setLpo(List<PO> lpo) {
this.lpo = lpo;
}
@Override
void attach(CMS childNode) {
this.getLpo().add((PO)childNode);
}
}
产品,由产品拥有,并拥有产品供应清单
package puzzler;
import java.util.List;
public class PO extends CMS {
List<POL> lpol;
public List<POL> getLpo() {
return lpol;
}
public void setLpo(List<POL> lpol) {
this.lpol = lpol;
}
@Override
void attach(CMS childNode) {
this.getLpo().add((POL)childNode);
}
}
PO拥有的产品供应清单(POL)
package puzzler;
public class POL extends CMS {
@Override
void attach(CMS childNode) {
throw new UnsupportedOperationException("Not supported yet.");
}
}
答案 0 :(得分:1)
(使用Java 7语法,但很容易适应Java 6)
按如下方式定义CMS类:
public abstract class CMS<C extends CMS<?>> {
public abstract void attach(C childNode);
}
然后您的Product类看起来像这样:
public class Product extends CMS<PO> {
private List<PO> lpo = new ArrayList<>();
public List<PO> getLpo() {
return lpo;
}
public void setLpo(List<PO> lpo) {
this.lpo = lpo;
}
@Override
public void attach(PO childNode) {
getLpo().add(childNode);
}
}
然后你的PO类看起来像这样:
public class PO extends CMS<POL> {
private List<POL> lpol = new ArrayList<>();
public List<POL> getLpo() {
return lpol;
}
public void setLpo(List<POL> lpol) {
this.lpol = lpol;
}
@Override
public void attach(POL childNode) {
getLpo().add(childNode);
}
}
然后你的POL类看起来像这样:
public class POL extends CMS<CMS<?>> {
@Override
public void attach(CMS<?> child) {
throw new UnsupportedOperationException("Not supported yet.");
}
}
最后,您的Tester类看起来像这样:
public class Tester {
public static void main(String[] args) {
Product p = new Product();
PO po = new PO();
List<PO> pos = new ArrayList<PO>();
List<POL> pols = new ArrayList<POL>();
attachChildToParent(pos, p);
attachChildToParent(pols, po);
}
private static <C extends CMS<?>> void attachChildToParent(List<C> childNodes, CMS<C> parent) {
for (C childNode : childNodes) {
parent.attach(childNode);
}
}
}
只需要一种方法,不需要演员表。
答案 1 :(得分:0)
只需使用具有合成模式的泛型,例如
答案 2 :(得分:0)
在实现类中使用的接口之类的抽象类需要在任何地方使用。
删除了其他演员阵容,并用一个替换了两个方法。
import java.util.ArrayList;
import java.util.List;
public class Tester {
public static void main(String[] args) {
Product p = new Product();
PO pa = new PO();
POL po = new POL();
List<CMS> lpa = new ArrayList<CMS>();
List<CMS> lpo = new ArrayList<CMS>();
attachChildToParent(lpa, p);
attachChildToParent(lpo, pa);
}
static void attachChildToParent(List<CMS> listChild, CMS parent) {
for (CMS po : listChild) {
parent.attach(po);
}
}
}
abstract class CMS {
abstract void attach(CMS childNode);
}
class Product extends CMS {
List<CMS> lpo;
public List<CMS> getLpo() {
return lpo;
}
public void setLpo(List<CMS> lpo) {
this.lpo = lpo;
}
@Override
void attach(CMS childNode) {
this.getLpo().add(childNode);
}
}
class PO extends CMS {
List<CMS> lpol;
public List<CMS> getLpo() {
return lpol;
}
public void setLpo(List<CMS> lpol) {
this.lpol = lpol;
}
@Override
void attach(CMS childNode) {
this.getLpo().add(childNode);
}
}
class POL extends CMS {
@Override
void attach(CMS childNode) {
throw new UnsupportedOperationException("Not supported yet.");
}
}