Android进阶之路1详解MVC

9次阅读

共计 2207 个字符,预计需要花费 6 分钟才能阅读完成。

最近因为换工作的原因没有写博客,现在慢慢稳定了,我准备写一些关于 Android 进阶的文章,也是为了督促自己学习,大家一起进步!
今天详细的分析一下 Android APP 架构之一:MVC

MVC 简介

MVC 全名是 Model View Controller,是模型 (model)-视图(view)-控制器(controller) 的缩写,一种软件设计典范,用一种业务逻辑、数据、界面显示分离的方法组织代码,将业务逻辑聚集到一个部件里面,在改进和个性化定制界面及用户交互的同时,不需要重新编写业务逻辑。MVC 被独特的发展起来用于映射传统的输入、处理和输出功能在一个逻辑的图形化用户界面的结构中。

大家有对 MVC 不了解的直接去百度百科,这里就不做过多的讲解了。

Android 中的 MVC

  • M 层:适合做一些业务逻辑处理,比如数据库存取操作,网络操作,复杂的算法,耗时的任务等都在 model 层处理。

    • V 层:应用层中处理数据显示的部分,XML 布局可以视为 V 层(虽然很牵强)
  • C 层:在 Android 中,Activity 处理用户交互问题,因此可以认为 Activity 是控制器,Activity 读取 V 视图层的数据

MVC 每层都有了解后,再对它构建一个导向图

我们为什么要用 MVC?

我们在写项目的时候 activity 太臃肿,需要把 View 与 Model 进行分离,这样的好处:
1. 耦合性低,利用 MVC 框架使得 View(视图)层和 Model(模型)层可以很好的分离
2. 方便维护
3. 不用重复的写相同的业务逻辑,实现 Model 与 Model 之间的调用,Controller 也可以直接调用 Model 来实现代码复用

从实例中强化了解 MVC

以之前做过的一个需求举例吧,“获取我的评论列表”目的就是获取评论的数据,并显示出来

步骤:
(1)

XML 视图布局我这里就不再写了,无非就是按钮、列表控件以及需要更新的 item 布局控件

(2)

为了实现 View 模块与 Model 的交互 (也就是 Model 执行完业务逻辑之后,需要通知给 View 去展示数据) 我们需要定义一个MyCommentListener

public interface MyCommentListener {

    /**
     * 加载我的评论列表成功的回调
     */
    void onMyCommentSuccess(MyCommentBean s);


    /**
     * 加载我的评论列表失败的回调
     */
    void onMyCommentFailure();}
(3)

Controller 与 Model 交互,也就是 C 层告诉 M 层获取评论的请求,它们之间的联系通过 MyCommentModel

public interface MyCommentModel {

    /**
     * 获取我的评论列表信息
     */
    void getMyCommentInfo(List<MyCommentBean.ResultBean> list, String page, MyCommentListener myCommentListener);


}
(4)

实现获取评论列表的逻辑,这很显然是 M 层

public class MyCommentModelImpl implements MyCommentModel {


    /**
     * 获取我的评论列表
     * @param list
     * @param myCommentListener
     */
    @Override
    public void getMyCommentInfo(final List<MyCommentBean.ResultBean> list, final String page, final MyCommentListener myCommentListener) {

        // 加载数据
        NetService.getInstance().rxJavaGetMyComment(Constans.USER_ID,page,"10")
                .subscribeOn(Schedulers.io())
                .observeOn(AndroidSchedulers.mainThread())
                .subscribe(new BaseSubscriber<MyCommentBean>() {

                    @Override
                    public void handlerSuccess(MyCommentBean s) {myCommentListener.onMyCommentSuccess(s);

               
                    }

                    @Override
                    public void onFailure() {myCommentListener.onMyCommentFailure();
                    }
                });
    }
}
(5)

Activity 或者 Fragment 实现 MyCommentListener 接口,看一下具体的回调:

 /**
     * 加载数据成功的回调
     */
    @Override
    public void onMyCommentSuccess(MyCommentBean s) {//View 做一些更新或者显示的操作}

    /**
     * 加载数据失败的回调
     *
     * @param type
     */
    @Override
    public void onMyCommentFailure() {//View 做一些更新或者显示的操作}

总结

1.mvc 提高了代码的重用性
1.Model 与 Model 之间可以调用,Controller 也可以无障碍直接调用 Model
2.Activity 或者 Fragment 中 包含了 C 层和 V 层,界面分割的不是很清晰,过于紧密了 …
3.View 对 Model 过于依赖

大家可以关注我的微信公众号:「秦子帅」一个有质量、有态度的公众号!

正文完
 0

Android进阶之路1详解MVC

9次阅读

共计 2207 个字符,预计需要花费 6 分钟才能阅读完成。

最近因为换工作的原因没有写博客,现在慢慢稳定了,我准备写一些关于 Android 进阶的文章,也是为了督促自己学习,大家一起进步!
今天详细的分析一下 Android APP 架构之一:MVC

MVC 简介

MVC 全名是 Model View Controller,是模型 (model)-视图(view)-控制器(controller) 的缩写,一种软件设计典范,用一种业务逻辑、数据、界面显示分离的方法组织代码,将业务逻辑聚集到一个部件里面,在改进和个性化定制界面及用户交互的同时,不需要重新编写业务逻辑。MVC 被独特的发展起来用于映射传统的输入、处理和输出功能在一个逻辑的图形化用户界面的结构中。

大家有对 MVC 不了解的直接去百度百科,这里就不做过多的讲解了。

Android 中的 MVC

  • M 层:适合做一些业务逻辑处理,比如数据库存取操作,网络操作,复杂的算法,耗时的任务等都在 model 层处理。

    • V 层:应用层中处理数据显示的部分,XML 布局可以视为 V 层(虽然很牵强)
  • C 层:在 Android 中,Activity 处理用户交互问题,因此可以认为 Activity 是控制器,Activity 读取 V 视图层的数据

MVC 每层都有了解后,再对它构建一个导向图

我们为什么要用 MVC?

我们在写项目的时候 activity 太臃肿,需要把 View 与 Model 进行分离,这样的好处:
1. 耦合性低,利用 MVC 框架使得 View(视图)层和 Model(模型)层可以很好的分离
2. 方便维护
3. 不用重复的写相同的业务逻辑,实现 Model 与 Model 之间的调用,Controller 也可以直接调用 Model 来实现代码复用

从实例中强化了解 MVC

以之前做过的一个需求举例吧,“获取我的评论列表”目的就是获取评论的数据,并显示出来

步骤:
(1)

XML 视图布局我这里就不再写了,无非就是按钮、列表控件以及需要更新的 item 布局控件

(2)

为了实现 View 模块与 Model 的交互 (也就是 Model 执行完业务逻辑之后,需要通知给 View 去展示数据) 我们需要定义一个MyCommentListener

public interface MyCommentListener {

    /**
     * 加载我的评论列表成功的回调
     */
    void onMyCommentSuccess(MyCommentBean s);


    /**
     * 加载我的评论列表失败的回调
     */
    void onMyCommentFailure();}
(3)

Controller 与 Model 交互,也就是 C 层告诉 M 层获取评论的请求,它们之间的联系通过 MyCommentModel

public interface MyCommentModel {

    /**
     * 获取我的评论列表信息
     */
    void getMyCommentInfo(List<MyCommentBean.ResultBean> list, String page, MyCommentListener myCommentListener);


}
(4)

实现获取评论列表的逻辑,这很显然是 M 层

public class MyCommentModelImpl implements MyCommentModel {


    /**
     * 获取我的评论列表
     * @param list
     * @param myCommentListener
     */
    @Override
    public void getMyCommentInfo(final List<MyCommentBean.ResultBean> list, final String page, final MyCommentListener myCommentListener) {

        // 加载数据
        NetService.getInstance().rxJavaGetMyComment(Constans.USER_ID,page,"10")
                .subscribeOn(Schedulers.io())
                .observeOn(AndroidSchedulers.mainThread())
                .subscribe(new BaseSubscriber<MyCommentBean>() {

                    @Override
                    public void handlerSuccess(MyCommentBean s) {myCommentListener.onMyCommentSuccess(s);

               
                    }

                    @Override
                    public void onFailure() {myCommentListener.onMyCommentFailure();
                    }
                });
    }
}
(5)

Activity 或者 Fragment 实现 MyCommentListener 接口,看一下具体的回调:

 /**
     * 加载数据成功的回调
     */
    @Override
    public void onMyCommentSuccess(MyCommentBean s) {//View 做一些更新或者显示的操作}

    /**
     * 加载数据失败的回调
     *
     * @param type
     */
    @Override
    public void onMyCommentFailure() {//View 做一些更新或者显示的操作}

总结

1.mvc 提高了代码的重用性
1.Model 与 Model 之间可以调用,Controller 也可以无障碍直接调用 Model
2.Activity 或者 Fragment 中 包含了 C 层和 V 层,界面分割的不是很清晰,过于紧密了 …
3.View 对 Model 过于依赖

大家可以关注我的微信公众号:「秦子帅」一个有质量、有态度的公众号!

正文完
 0