这是voo的答案,并提供了有关后期绑定的替代方法的详细信息。
通用JVM仅使用 单一调度
:仅将运行时类型作为接收方对象使用;对于方法的参数,将考虑静态类型。使用方法表(类似于C
++的虚拟表),使用优化进行有效的实现非常容易。您可以在HotSpot
Wiki中找到详细信息。
如果您想对参数进行 多次分派 ,请查看
- 时髦。但是据我所知,它具有过时的,缓慢的多重调度实现(例如,参见性能比较),例如没有缓存。
- clojure,但这与Java完全不同。
- MultiJava,它为Java提供了多个调度。此外,您可以使用
this.resend(...)
而不是super(...)
调用封闭方法中最具体的覆盖方法;- 值分配(下面的代码示例)。
如果您想 坚持使用Java ,可以
- 通过将重载方法移至更细粒度的类层次结构来重新设计应用程序。Josh Bloch的有效Java项目41(明智地使用重载)中给出了一个示例;
- 使用一些设计模式,例如策略,访客,观察者。这些通常可以解决与多重分派相同的问题(即,在这种情况下,使用多重分派可以为那些模式提供简单的解决方案)。
价值分配:
class C { static final int INITIALIZED = 0; static final int RUNNING = 1; static final int STOPPED = 2; void m(int i) { // the default method } void m(int@@INITIALIZED i) { // handle the case when we're in the initialized `state' } void m(int@@RUNNING i) { // handle the case when we're in the running `state' } void m(int@@STOPPED i) { // handle the case when we're in the stopped `state' }}
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)