动态改变执行方法

栏目: Java · 发布时间: 7年前

内容简介:版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/thc1987/article/details/83001079

版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/thc1987/article/details/83001079

题目:有一个接口Processor,分别被ServiceA和ServiceB实现。

interface Processor {
    void process();
}

class ServiceA implements Processor {
    @Override
    public void process() {
        System.out.println("run ServiceA...");
    }
}

class ServiceB implements Processor {
    @Override
    public void process() {
        System.out.println("run ServiceB...");
    }
}

要求前10次由ServiceA运行,超过10次后自动切换成ServiceB运行。

代码如下:

interface Processor {
    void process();
}

class ServiceA implements Processor {
    @Override
    public void process() {
        System.out.println("run ServiceA...");
    }
}

class ServiceB implements Processor {
    @Override
    public void process() {
        System.out.println("run ServiceB...");
    }
}

public class DynamicRun {

    static class ProcessRunner implements Processor {

        private DelegateProcess target;
        private int runCount;

        private ServiceA defaultProcessor = new ServiceA();

        @Override
        public void process() {
            int count = ++this.runCount;
            System.out.println("默认运行次数:" + count);
            if (count >= 10) {
                System.out.println("默认运行次数到达10次,切换为ServiceB运行");
                // 将真正processor改为ServiceB
                this.target.setDelegate(new ServiceB());
            }

            defaultProcessor.process();
        }

        public void setTarget(DelegateProcess target) {
            this.target = target;
        }

    }

    static class DelegateProcess implements Processor {

        private Processor delegate;

        private DelegateProcess(Processor delegate) {
            this.delegate = delegate;
        }

        @Override
        public void process() {
            delegate.process();
        }

        public void setDelegate(Processor delegate) {
            this.delegate = delegate;
        }

    }

    public static void main(String[] args) {
        // 拿到这个processor,可在其它地方运行,不受约束
        Processor processor = buildProcessor();
        for (int i = 0; i < 15; i++) {
            processor.process();
        }
    }

    private static Processor buildProcessor() {
        ProcessRunner processRunner = new ProcessRunner();
        DelegateProcess delegateProcess = new DelegateProcess(processRunner);
        processRunner.setTarget(delegateProcess);
        return delegateProcess;
    }

}

此方式在JDK中也有出现,可以参考 sun.reflect.ReflectionFactory.newMethodAccessor() 方法。该方法在使用 Method.invoke() 时用到。代码片段如下:

NativeMethodAccessorImpl var2 = new NativeMethodAccessorImpl(var1);
DelegatingMethodAccessorImpl var3 = new DelegatingMethodAccessorImpl(var2);
var2.setParent(var3);

以上所述就是小编给大家介绍的《动态改变执行方法》,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对 码农网 的支持!

查看所有标签

猜你喜欢:

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

互联网思维独孤九剑

互联网思维独孤九剑

赵大伟 / 机械工业出版社 / 2014-3-20 / 49

《互联网思维独孤九剑》是国内第一部系统阐述互联网思维的著作,用9大互联网思维:用户思维、简约思维、极致思维、迭代思维、流量思维、社会化思维、大数据思维、平台思维、跨界思维,以专业的视角全方位解读移动互联网给传统产业带来的变革,涉及战略规划、商业模式设计、品牌建设、产品研发、营销推广、组织转型、文化变革等企业经营价值链条的各个方面。这是一部传统企业互联网转型必读的“孙子兵法”,帮助我们开启对新商业文......一起来看看 《互联网思维独孤九剑》 这本书的介绍吧!

随机密码生成器
随机密码生成器

多种字符组合密码

RGB CMYK 转换工具
RGB CMYK 转换工具

RGB CMYK 互转工具

HEX CMYK 转换工具
HEX CMYK 转换工具

HEX CMYK 互转工具