《Android源码设计模式解析和实战》模块方法模式

按照一定步骤执行方法,当时步骤内的方法可能发生修改或添加。
步骤
<pre>
public abstract class Module {
private static final String TAG = "Module";

protected void aVoid() {
    Log.i(TAG, "开始: ");
}

protected void bVoid() {
    Log.i(TAG, "加速: ");
}

protected void cVoid() {
    Log.i(TAG, "减速: ");
}

protected void dVoid() {
    Log.i(TAG, "结束: ");
}

public final void running() {
    Log.i(TAG, "running: 跑步---------------------");
    aVoid();
    bVoid();
    cVoid();
    dVoid();
    Log.i(TAG, "running: 跑步------------------------");
}

</pre>
A
<pre>
public class ModuleImplA extends Module {
private static final String TAG = "ModuleImplA";
@Override
protected void aVoid() {
Log.i(TAG, "ModuleImplA: 提前开始");
}
}
</pre>
B
<pre>
public class ModuleImplB extends Module {
private static final String TAG = "ModuleImplB";

@Override
protected void dVoid() {
    Log.i(TAG, "ModuleImplB: 提前结束");
}

}
</pre>
使用
<pre>
public class MainActivity extends AppCompatActivity {
private static final String TAG = "MainActivity";

@Override
protected void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.activity_main);
    Module module = new ModuleImplA();
    module.running();
    module = new ModuleImplB();
    module.running();
    module = new Module() {
        @Override
        protected void aVoid() {
            super.aVoid();
            Log.i(TAG, "MainActivity: 重新开始 ");
        }
    };
    module.running();
}

</pre>
log
<pre>
03-13 21:44:58.820 26327-26327/com.lerz.moduledmeo I/Module: running: 跑步---------------------
03-13 21:44:58.820 26327-26327/com.lerz.moduledmeo I/ModuleImplA: ModuleImplA: 提前开始
03-13 21:44:58.820 26327-26327/com.lerz.moduledmeo I/Module: 加速:
03-13 21:44:58.820 26327-26327/com.lerz.moduledmeo I/Module: 减速:
03-13 21:44:58.820 26327-26327/com.lerz.moduledmeo I/Module: 结束:
03-13 21:44:58.820 26327-26327/com.lerz.moduledmeo I/Module: running: 跑步------------------------
03-13 21:44:58.820 26327-26327/com.lerz.moduledmeo I/Module: running: 跑步---------------------
03-13 21:44:58.820 26327-26327/com.lerz.moduledmeo I/Module: 开始:
03-13 21:44:58.820 26327-26327/com.lerz.moduledmeo I/Module: 加速:
03-13 21:44:58.820 26327-26327/com.lerz.moduledmeo I/Module: 减速:
03-13 21:44:58.820 26327-26327/com.lerz.moduledmeo I/ModuleImplB: ModuleImplB: 提前结束
03-13 21:44:58.820 26327-26327/com.lerz.moduledmeo I/Module: running: 跑步------------------------
03-13 21:44:58.820 26327-26327/com.lerz.moduledmeo I/Module: running: 跑步---------------------
03-13 21:44:58.820 26327-26327/com.lerz.moduledmeo I/Module: 开始:
03-13 21:44:58.820 26327-26327/com.lerz.moduledmeo I/MainActivity: MainActivity: 重新开始
03-13 21:44:58.820 26327-26327/com.lerz.moduledmeo I/Module: 加速:
03-13 21:44:58.820 26327-26327/com.lerz.moduledmeo I/Module: 减速:
03-13 21:44:58.820 26327-26327/com.lerz.moduledmeo I/Module: 结束:
03-13 21:44:58.820 26327-26327/com.lerz.moduledmeo I/Module: running: 跑步------------------------
</pre>

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • Android 自定义View的各种姿势1 Activity的显示之ViewRootImpl详解 Activity...
    passiontim阅读 175,270评论 25 709
  • Spring Cloud为开发人员提供了快速构建分布式系统中一些常见模式的工具(例如配置管理,服务发现,断路器,智...
    卡卡罗2017阅读 135,359评论 19 139
  • 现在的男女认识真的 好简单,陌陌?探探?附近的人?等等各种交友平台,往往这样的感情真的不会有人去珍惜吧毕竟来的太快...
    过呀过呀阅读 1,872评论 0 0
  • 今天写什么,思想近于枯竭,怎么会这样,越来越不知道写什么。 此时,天空阴云密布,黑压压的,气候又湿又闷,闷得发慌。...
    码字好玩儿阅读 2,972评论 0 0
  • 滋蘭阅读 1,911评论 0 0