浅谈架构模式-mvc,mvp

本文详细介绍了MVC和MVP两种软件架构模式的区别及应用。MVC将应用程序分为模型、视图和控制器三个部分;MVP则分为模型、视图和呈现器。文章通过登录示例展示了MVP的具体实现过程。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

开门见山,宝宝不多说什么,来直接简单了解一下mvcmvp架构模式的区别以及用法吧。

MVC


MVCmodle view controller的缩写。

 

M-- 模型javabean

V-- layout布局文件

C-- 控制器Activity/fragment,里面编写逻辑if/else switch +thread

mvc大家都很熟悉了,我就不多说什么了。今天来主要了解一下mvp吧。


MVP

mvp是目前比较流行的软件开发方式,相对MVC来做可以降低代码耦合度。但是会出现很多接口。



mvpmodle view presenter的缩写

 

M-- 模型javabean

V-- activiy/fragment

P-- Presenter里面编写逻辑if/else switch +thread

 

mvpM V P这三个模块分别对应一个接口

mvp有专门的单元测试:可以分层测试每一层(mock),在这里不介绍

编写步骤

1.分包 model view presenter

2.分别写出M V P的代码,然后分别对应抽取接口。

快速生成一个类的接口:选中类中方法名 右键Rafactor--Extra--Interface


献上一个登陆例子方便大家理解:


model模块:

UserInfo 代码:

public class UserInfo implements IUserModel {
    public String username;
    public String pwd;
    @Override
    public String getUsername() {
        return username;
    }
    @Override
    public void setUsername(String username) {
        this.username = username;
    }
    @Override
    public String getPwd() {
        return pwd;
    }
    @Override
    public void setPwd(String pwd) {
        this.pwd = pwd;
    }
}

然后选中UserInfo 生成IUserModel 接口代码。在此就不贴代码了


presenter模块

LoginPresenter 代码:

public class LoginPresenter implements ILoginPresenter {
    private static final String TAG = "LoginPresenter";
    Handler mHandler = new Handler();
    ILoginView view;
    public LoginPresenter(ILoginView mainActivity) {
        this.view = mainActivity;
    }
    @Override
    public void login(final String userInput, final String pwdInput) {
        view.showLoading(true);
        if (TextUtils.isEmpty(userInput) || TextUtils.isEmpty(pwdInput)) {
            //提示账号和密码不能为空
            Log.e(TAG, "账号和密码不能为空 ");
            view.showError();
        } else {
            //模拟提交给服务器的耗时操作,服务器返回 true:成功  false:失败
            mHandler.postDelayed(new Runnable() {
                @Override
                public void run() {
                    boolean flag = false;
                    //model模块的javabean
                    IUserModel user = new UserInfo();
                    user.setUsername("xiaozhu");
                    user.setPwd("123");
                    if (user.getUsername().equals(userInput) && user.getPwd().equals(pwdInput)) {
                        flag = true;
                    } else {
                        flag = false;
                    }
                    if (flag) {
                        //登录成功的提示
                        Log.e(TAG, "登录成功 ");
                        view.showSuccess();
                    } else {
                        //登录失败的提示
                        Log.e(TAG, "登录失败,账号或者密码错误 ");
                        view.showError();
                    }
                }
            }, 1000);
        }
    }
}

同样自动生成接口代码,在这里不贴代码了


view模块:

public class MainActivity extends AppCompatActivity implements ILoginView {

    @InjectView(R.id.bt_login)
    Button btLogin;
    @InjectView(R.id.pb)
    ProgressBar pb;
    @InjectView(R.id.et_username)
    EditText etUsername;
    @InjectView(R.id.et_pwd)
    EditText etPwd;
    private ILoginPresenter loginPresenter;

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
        ButterKnife.inject(this);
        //引入presenter模块的逻辑
        loginPresenter = new LoginPresenter(this);
    }
    @OnClick(R.id.bt_login)
    public void login() {
        String username = etUsername.getText().toString().trim();
        String pwd = etPwd.getText().toString().trim();
        loginPresenter.login(username, pwd);
    }
    /**
     * 是否显示进度圈
     */
    @Override
    public void showLoading(boolean isShowLoadding) {
        pb.setVisibility(isShowLoadding ? View.VISIBLE : View.INVISIBLE);
    }
    /**
     * 显示登录错误提示
     */
    @Override
    public void showError() {
        showLoading(false);
        Toast.makeText(this, "账号或者密码错误", Toast.LENGTH_SHORT).show();
    }
    /**
     * 显示登录成功的提示
     */
    @Override
    public void showSuccess() {
        showLoading(false);
        Toast.makeText(this, "登录成功", Toast.LENGTH_SHORT).show();
    }
}

同样在此就不贴布局文件代码和接口ILoginView 代码了。

运行结果:


MVPHelper插件:

如果你嫌麻烦,不愿意慢慢的分包然后生成对应的接口,可以使用这个插件,它会自动的生成对应的包和类。

安装插件:



MVPHelper第一种使用方式:

1.先创建一个接口类型的IloginPresenter(注意Presenter单词要拼写对,否则会产生错误)

2.然后指定放在一个presenter的包下面


3.然后alt+insert,出现如下图所示的框,选择MVPHelper


4.然后就会自动给你分好包了



MVPHelper第二种生成接口集合的使用方式:

1.再创建一个包model2,然后生成下图所述的类



然后再使用插件就能生成该有的几个类



资源下载链接为: https://pan.quark.cn/s/22ca96b7bd39 在当今的软件开发领域,自动化构建与发布是提升开发效率和项目质量的关键环节。Jenkins Pipeline作为一种强大的自动化工具,能够有效助力Java项目的快速构建、测试及部署。本文将详细介绍如何利用Jenkins Pipeline实现Java项目的自动化构建与发布。 Jenkins Pipeline简介 Jenkins Pipeline是运行在Jenkins上的一套工作流框架,它将原本分散在单个或多个节点上独立运行的任务串联起来,实现复杂流程的编排与可视化。它是Jenkins 2.X的核心特性之一,推动了Jenkins从持续集成(CI)向持续交付(CD)及DevOps的转变。 创建Pipeline项目 要使用Jenkins Pipeline自动化构建发布Java项目,首先需要创建Pipeline项目。具体步骤如下: 登录Jenkins,点击“新建项”,选择“Pipeline”。 输入项目名称和描述,点击“确定”。 在Pipeline脚本中定义项目字典、发版脚本和预发布脚本。 编写Pipeline脚本 Pipeline脚本是Jenkins Pipeline的核心,用于定义自动化构建和发布的流程。以下是一个简单的Pipeline脚本示例: 在上述脚本中,定义了四个阶段:Checkout、Build、Push package和Deploy/Rollback。每个阶段都可以根据实际需求进行配置和调整。 通过Jenkins Pipeline自动化构建发布Java项目,可以显著提升开发效率和项目质量。借助Pipeline,我们能够轻松实现自动化构建、测试和部署,从而提高项目的整体质量和可靠性。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值