使方法可重复使用

时间:2012-08-17 14:17:21

标签: java oop

我今天早些时候问了一个类似的问题,但现在我被告知要求已经改变了。

我有3个课程 - ProductProductOffering(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.");
    }
}

3 个答案:

答案 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)

只需使用具有合成模式的泛型,例如

  • 将CMS定义为接口
  • 定义单个类PO,按类型
  • 进行参数化
  • 在CMSImpl中实现方法一次

http://en.wikipedia.org/wiki/Generics_in_Java

http://en.wikipedia.org/wiki/Composite_pattern

答案 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.");
  }
}