
在写 Java 程序的时候遇到了如下格式的逻辑: if (s instanceof FunctionDef) { ... } else if (s instanceof ClassDef) { ... } else if (s instancef Return) { ... } ...
对于这种代码该如何重构才能使得程序看上去更加简洁并且高效?
1 knightdf 2016 年 4 月 12 日 换成 Scala 用 match case, 哈哈 |
2 ahmiao 2016 年 4 月 12 日 统一接口+子类化? |
3 wanghaa 2016 年 4 月 12 日 |
4 gqlxj1987 2016 年 4 月 12 日 工厂+策略模式 |
5 zhuangzhuang1988 2016 年 4 月 12 日 import java.util.HashMap; import java.util.LinkedList; import java.util.List; import java.util.Map; abstract class Validate { abstract boolean validate(Object obj); abstract void process(Object val); } class A { } class B { } class AValidate extends Validate { @Override boolean validate(Object obj) { return obj instanceof A; } @Override void process(Object val) { A a = (A)val; // ... } } class BValidate extends Validate { @Override boolean validate(Object obj) { return obj instanceof B; } @Override void process(Object val) { B a = (B)val; // ... } } public class Main { public static void main(String[] args) { Object a = new A(); Validate[] validates = { new AValidate(), new BValidate() }; for(Validate v: validates ){ if(v.validate(a)){ v.process(a); break; } } } } 试试下. |
6 beanlam 2016 年 4 月 12 日 用多态,一个分支对应一个实现。这种方法对于有大量分支的情况可能不适用,因为要写大量的类。 另外一种模式可以参考《代码大全》第十八章提到的“表驱动模式”。 |
7 SpicyCat 2016 年 4 月 12 日 @ahmiao 同意用接口加子类。 FunctionDef, ClassDef 和 Return 可以实现同一个接口或者继承同一个父类,假设父类叫 Father, 方法名叫 doSomething(), 然后那三个子类各自实现 doSomething(). 这样代码里只需要调用 Father#doSomething 就可以了。 |
8 levn 2016 年 4 月 12 日 改成一种更加复杂难懂的方式 |
9 cxshun 2016 年 4 月 12 日 面向接口编程,多态就是这个时候用的。 |
10 fwrq41251 2016 年 4 月 12 日 访问者模式。 或者用 java8 ,有个叫 javaslang 的类库,有用于类型匹配的类。 |
11 SoloCompany 2016 年 4 月 12 日 首选是多态 不适合多态的可以试一下 Kotlin 用 case when 来代替了 if else 而已也没啥区别 |
12 wanttofly 2016 年 4 月 12 日 谢谢回答,最近正好有这方面的修改。 |
15 zhuangzhuang1988 2016 年 4 月 12 日 或者看这种解决方式, 当然有点难 `functional-programming-in-scala` 作者写的 http://blog.higher-order.com/blog/2009/08/21/structural-pattern-matching-in-java/ |
16 kaneg 2016 年 4 月 12 日 这不就是多态要解决的问题吗 |
17 twoyuan 2016 年 4 月 12 日 我现在是建一个 Map<Class, Callback> map ,用的时候 map.get(object.class)。不过第一次创建时会慢点 |
18 Jaylee 2016 年 4 月 12 日 这应该是用多态吧 |
19 laibin 2016 年 4 月 12 日 访问者模式。 |
20 haolly 2016 年 4 月 12 日 重面,你看到大量 switch 或者 if-else 的候,表示你用多了 |