看到HR桌面上的几份简历,我总能看到MVC的身影,但为什么都喜欢把这东西往简历上贴呢,它真的有那么厉害吗?可能小弟我造诣实在太低了,在实际项目中基本没用过这东西,哪怕用了也不知道吧。
这玩意是个什么鬼,其实我也知道个大概,有人说是设计模式,也有人说是框架,但我更偏向于设计模式。据我的了解,设计模式是为了代码重用而设计的模式,而框架是为了模块重用而搭建,也可以说是轮子,直接用或者扩展。
好了,模式也好,框架也好,其实也没必要深究,说到底还是为了开发的效率而已,那么MVC究竟是如何运作呢,尽管小项目用不到,还是沉淀沉淀下吧,少年~
Model模型,View视图和Controller控制器,三者的结合就成了MVC。
首先,建立一个Student类作为模型:
Student.java
public class Student {
private int id;
private String name;
public int getId() {
return id;
}
public void setId(int id) {
this.id = id;
}
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
}
View.java
public class View {
public void show(int what){
System.out.println(what);
}
public void show(String what){
System.out.println(what);
}
}
最后,通过控制器来获取学生信息,并将信息展示到视图上:
Controller.java
public class Controller {
Student student;
View v;
public Controller(Student student, View v){
this.student=student;
this.v=v;
}
public int getStudentId(){
return student.getId();
}
public String getStudentName(){
return student.getName();
}
public void printStudentInfo(){
v.show(getStudentId());
v.show(getStudentName());
}
}
写个运行类测试下:
PatternTest.java
public class PatternTest {
public static void main(String[] args) {
// TODO Auto-generated method stub
Student student=new Student();
student.setId(2015);
student.setName("Samuel");
View view=new View();
Controller controller=new Controller(student, view);
controller.printStudentInfo();
}
}
实际上控制器类(Controller)是通过模型(Model)和视图(View)两个实例进行初始化的,也就是控制器持有模型和视图的句柄,即控制权,通过控制器类来控制从数据库建模,到将模型数据输出到视图,这样一来就降低了模型和视图的耦合性,当更改模型数据时,只需要在控制器添加相应的业务就行了,并不需要更改视图,从而增强了视图的复用性。
比如,在模型里给Student增加一个年龄age属性,那么我只需要在Controller的printStudentInfo函数中增加v.show(getStudentAge())业务即可,并不需要修改视图。
作为一个Android开发者,若非得从小项目里挖个MVC实例出来,个人认为,ListView的显示也勉强算是个的MVC模式了吧。List<Map<String, Object>>存放了一个个模型,而ListView则作为显示的视图,继承其适配器类BaseAdapter并编写需要如何显示,显示式样等业务,充当着Controller的角色。当List<Map<String, Object>>里的模型数据发生变化时,Adapter调用notifyDataSetChange()函数则可以更新视图。