What is MVC in Java?

First, what is MVC?

Model: model layer

Views: view layers

Controller: control layer

MVC (Modal View Controller) originally existed in desktop programs, where M refers to data model, V refers to user interface and C is controller. The purpose of using MVC is to separate the implementation codes of M and V, so that the same program can use different forms of expression. For example, a batch of statistical data can be represented by histogram and pie chart respectively. The purpose of C is to ensure the synchronization of M and V. Once M changes, V should be updated synchronously.

Model-View-Controller (MVC) is a software design pattern invented by PARC Xerox Company on behalf of the programming language Small Talk-80 in 1980s, and it is still widely used today. In recent years, it has been recommended as the design pattern of Sun's J2EE platform, and has been welcomed by more and more developers who use ColdFusion and PHP. Model-view-controller mode is a useful toolbox, which has many advantages, but also some disadvantages.

Second, how does MVC work

MVC is a design pattern, which forcibly separates the input, processing and output of an application. Applications using MVC are divided into three core components: model, view and controller. They each deal with their own tasks.

visual angle

A view is an interface that users see and interact with. For old Web applications, a view is an interface composed of HTML elements. In the new Web application, HTML still plays an important role in views, but some new technologies have emerged one after another, including Macromedia Flash and some markup languages such as XHTML, XML/XSL, WML and Web services.

How to deal with the interface of the application becomes more and more challenging. One of the great benefits of MVC is that it can handle many different views for your application. In fact, there is no real processing in the view, no matter whether the data is stored online or the employee list, as a view, it is just a way to output data and allow users to manipulate the data.

model

This model represents enterprise data and business rules. Among the three components of MVC, the model has the most processing tasks. For example, it may use component objects such as EJB and ColdFusion components to process databases. The data returned by the model is neutral, that is, the model has nothing to do with the data format, so a model can provide data for multiple views. Because the code applied to the model can be reused by multiple views only once, the code duplication is reduced.

controller

The controller accepts users' input and calls models and views to meet users' needs. So when clicking the hyperlink in the web page and sending the HTML form, the controller itself does not output anything or do anything. It just receives the request and decides which model component to call to process the request, and then decides which view to use to display the data returned by the model processing.

Now let's summarize the MVC process. First, the controller receives the user's request and decides which model should be called for processing. Then the model uses business logic to process the user's request and return the data. Finally, the controller formats the data returned by the model with the corresponding view and presents it to the user through the presentation layer.

Third, why use MVC?

Most Web applications are created in procedural languages such as ASP, PHP or CFML. They mix data layer codes such as database query statements with presentation layer codes such as HTML. Experienced developers will separate the data from the presentation layer, but this is usually not easy to do. It requires careful planning and trial and error. MVC fundamentally forced them to separate. Although it takes some extra work to build MVC applications, the benefits it brings us are beyond doubt.

First and foremost, multiple views can share a model. As I mentioned, there are more and more ways to access your application. In this regard, one of the solutions is to use MVC, whether your users want Flash interface or WAP interface; They can be treated with models. Because the data and business rules have been separated from the presentation layer, the code can be reused to the greatest extent.

Because the data returned by the model is not formatted, the same component can be used by different interfaces. For example, a lot of data may be expressed in HTML, but it may also be expressed in Macromedia Flash and WAP. The model also has the functions of state management and data persistence. For example, session-based shopping carts and e-commerce processes can also be reused by Flash websites or wireless network applications.

Because the model is self-contained and separated from the controller and view, it is easy to change the data layer and business rules of the application. If you want to transplant your database from MySQL to Oracle, or change your RDBMS-based data source to LDAP, just change the model. Once you implement the model correctly, the view will display your data correctly whether it comes from a database or an LDAP server. Because the three components of an application using MVC are opposite to each other, changing one of them will not affect the other two, so you can construct a good loosely coupled component according to this design idea.

For me, the controller also provides a benefit, that is, it can be used to connect different models and views to meet the needs of users, so that the controller can provide a powerful means for constructing applications. Given some reusable models and views, the controller can select the model to process according to the user's needs, and then select the view to display the processing results to the user.

Fourth, the shortcomings of MVC.

The disadvantage of MVC is that it is not easy to fully understand MVC because it has no clear definition. Using MVC requires careful planning. Because of its complicated internal principle, it needs some time to think.

You will have to spend a lot of time thinking about how to apply MVC to your application. At the same time, it will be difficult to debug your application, because the model and view should be strictly separated. Each component needs to be thoroughly tested before use. Once your components have been tested, you can reuse them without scruple.

According to my personal experience, since we divide an application into three parts, it is obvious that using MVC also means that you will manage more files than before. It seems that our workload has increased, but please remember that this is nothing compared with the benefits it can bring us.

MVC is not suitable for small or even medium-sized applications, and it is usually not worth the loss to spend a lot of time applying MVC to small applications.

Advantages of MVC: MVC is a good way to create software.

MVC design pattern is a good way to create software, and some principles it advocates, such as the separation of content and display, may be easier to understand. However, if you want to isolate the components of the model, view and controller, you may need to reconsider your application, especially its architecture. If you are willing to accept MVC and have the ability to cope with the extra work and complexity it brings, MVC will make your software by going up one flight of stairs in robustness, code reuse and structure.

I hope it helps you! ~