MVP,即 Model-View-Presenter ,是一种高效灵活的软件开发架构模式,它将用户界面(User Interface,UI)、数据(Data)和逻辑处理(Navigation)分离,整个程序更易于维护和拓展。在安卓开发中,MVP模式是非常流行的设计模式。
MVP模式的架构分为三层:View、Presenter和Model。
1. View层
View层主要是由UI、Activity和Fragment组成。UI中就是安卓中的布局,如:TextView、Button等。Activity和Fragment主要是负责展示数据、响应操作、以及与Presenter交互。
2. Presenter层
Presenter层主要是负责处理View和Model层之间的沟通,如View的事件响应处理和Model数据的请求与响应。同时Presenter层也有一个非常重要的作用,那就是将View层从Model层的逻辑中解耦出来,保证Model层只负责数据的获取和处理。
3. Model层
Model层主要是负责获取和处理数据,比如WebAPI、本地存储等。
在MVP模式中,View层和Model层之间完全解耦,Presenter层作为桥梁联系起来,实现了软件设计的"单一职责原则",该原则指一个类的职责应该是单一的。
使用MVP模式的优点:
1. 使UI和业务逻辑分离,可以方便的修改UI而不影响业务逻辑;
2. 方便单元测试,实现了视图和业务逻辑的分离;
3. 更高效的团队协作,UI、业务逻辑、数据处理分离,可以个人负责关注自己负责的领域,提高开发效率;
4. 功能拓展可靠性高,由于MVP模式将View和Model分开,并且通过Presenter来交互,所以在程序维护时,拓展功能(增加View或Model层)时,不会影响软件的其他功能;
使用MVP模式的缺点:
1. 增加了程序的复杂度;
2. 程序结构相对而言复杂,不太适合小规模的应用程序。
总之,MVP模式作为一种设计模式存在很长时间,大多数框架都已经将其实现了,MVP模式能够提高代码质量、可维护性以及代码可读性,更好的满足企业级应用程序的开发需求。