请问JAVA三层架构,持久层,业务层,表现层,都该怎么理解?和MVC三层模型有什么
MVC就是Model-View-Control
创新互联公司专业为企业提供离石网站建设、离石做网站、离石网站设计、离石网站制作等企业网站建设、网页设计与制作、离石企业网站模板建站服务,十余年离石做网站经验,不只是建网站,更提供有价值的思路和整体网络服务。
(控制器Controller)-
负责转发请求,对请求进行处理。
(视图View)
-
界面设计人员进行图形界面设计。
(模型Model)
-
程序员编写程序应有的功能(实现算法等等)、数据库专家进行数据管理和数据库设计(可以实现具体的功能)。
基本上Controller跟业务层差不多
View就是表现层,Model就是持久层
基本的思想就是软件各个模块之间尽量松耦合,通过接口通讯,比如你从数据库中获取数据都是通过一个固定的接口,只要接口不变,在修改底层跟数据库通讯的代码的时候(比如你之前用MySQL,现在想用SQL
Server了)就不会影响到业务层跟表现层。同时各个部分逻辑更加清晰。
介绍下Java程序的结构
Java语言是面向对象的程序设计语言,Java程序的基本组成单元是类,类体中又可包括属性与方法两部分。而每一个应用程序都必须包含一个main()方法,含有main()方法的类称之为主类。
一: Java程序的主类及其格式
作为一个可以独立运行的Java程序,在它的众多类中必须要有一个类作为程序的起始类,为了方便,本书把这个类称为主类。当需要执行一个程序时,人们在java命令后面输入的便是这个主类的文件名(也是主类名),因此主类文件是Java运行环境建立起来之后第一个被装入虚拟机的用户文件。为了使虚拟机可以找到程序运行的起始入口,主类必须为public类,并含有一个在格式上符合约定的入口方法main(),其格式如下:
public static void main(String[] args){
…
}
其中各参数含义如下。
main:入口方法名称。
args:命令行参数,这是一个String对象数组。
static:修饰字,说明main()是一个静态方法(类方法)。
public:修饰字,说明main()具有公有访问属性。
于是,主类框架的源代码如下:
public class 主类名{
…
public static void main(String[] args){
…
}
}
Java程序的主类常常使熟悉C/C++的读者感到迷惑:main()方法不就相当于C/C++程序中的主函数吗,为什么非得把它放到一个类里,难道它有什么不同吗?
没错,Java类中main()方法就相当于C/C++程序中的主函数,是一个入口函数。之所以把它封装到一个类里,而不像C/C++那样单独作为一个函数来处理,就本书作者的理解,大概Java的设计者们有如下几个方面的考虑。
1)Java既然把所有事物都看成了对象,那么就没有理由不把程序也看成对象,因为程序也是一种事物。既然是对象,那么它就应该属于某个类并以程序名来命名。既然程序是一种类,那么main()就应该是这个类的一个方法,只不过它有些特殊,它是一个入口方法,并且对它有些特殊规定,例如其名称必须为main(),必须是公有静态方法,有命令行参数等。
2)如果把程序封装成了类,那么包括本程序在内的任何程序就都可以根据需要,随时创建这个类的对象,并通过该对象使用这个类中的资源,这样就便于资源共享,从而提高程序的灵活性。
3)Java程序是一种以类为基本单位的模块化程序,程序被编译后,每一个类会对应生成一个二进制字节码类文件。如果把程序也封装成类,那么它的文件就与其他类文件统一起来,而不会产生其他类型的文件,因而便于管理。
4)之所以把入口方法封装到类中,其根本目的就是要尽可能平等地看待所有的类。因为Java的最终目的是要以类为基本模块来实现可装配软件,如果把main()方法封装到了一个类中,那么就意味着main()与类的其他方法没什么本质区别,只不过是分工不同而已。下面很快就会看到,Java的所有类都可以含有一个入口方法而成为主类。也就是说,在Java程序中根本就没有主类、次类之分,这里之所以把带有main()方法的类称为主类,是为了表达方便。
二: JAVA源程序在命令行下的运行
class Bank{
public void init(){
System.out.println("Yes,I can");
}
public static void main(String args[]){
BankAccount ba1 = new BankAccount(100.00);
System.out.print("Before transactions, ");
ba1.display();
ba1.deposit(74.35);
ba1.withdraw(20.00);
System.out.print("After transactions, ");
ba1.display();
Bank b = new Bank();
b.init();
}
}
class BankAccount{
private double balance;
public BankAccount(double openingBalance){
balance = openingBalance;
}
public void deposit(double amount){
balance += amount;
}
public void withdraw(double amount){
balance -= amount;
}
public void display(){
System.out.println("balance = " + balance);
}
}
三:完整的java源程序应该包括下列部分
package语句;
import语句;
public classDefinition; // 公共的类定义部分,至多只有一个公共类的定义
// java语言规定该java源程序的文件名必须与该公共类名完全一致
classDefinition; // 类定义部分,可以有0个或多个
interfaceDefinition; // 接口定义部分,可以有0个或多个
package:java编译器为每个类生成一个字节码文件,且文件名与类名相同,这就会带来一个问题:同名的类会发生冲突。package便可管理类命名空间。
一般地,具有相同功能的类放在一个package中。
一个java源程序至多只能有一个公共类的定义。
若java源程序有一个公共类的定义,则该源文件名字必须与该公共类的名字完全相同。
若源程序中不包含公共类的定义,则该文件名可以任意取名。
若一个源程序中有多个类定义,则在编译时将为每个类生成一个。class文件。
三。java编程规范
包名:全小写的名词,中间可由点分割,eg:java.awt.event
类名:首字母大写,多个单词合成,每个单词首字母也要大写,eg: class HelloWorldApp
接口名: 同类名,eg: interface Collection
方法名: 由多个单词合成,第一个单词通常为动词,首字母小写,中间的每个单词的首字母都要大写,eg: balanceAccount, isButtonPressed
变量名: 全小写,一般为名词,eg: length
常量名: 基本数据类型的常量名为全大写,如果由多个单词构成,可以用下划线隔开,eg: int YEAR, int WEEK_OF_MONTH
对象类型的常量,则是小写混合,由大写字母把单词隔开
java中的4层架构,为什么要将3层分层4层,这样有什么好处,4层后,每层是干什么的
分层的好处就在于代码清晰,结构分明,有利于修改和维护。增加代码的可读性。我6层的都用过。
北大青鸟java培训:分层架构的优缺点有哪些?
在进行软件开发过程中,为了能够更有效的执行系统架构,一般情况下需要进行分层结构的形式来构成。
那么在使用分层架构的过程中有哪些优缺点呢?下面电脑培训为大家具体介绍。
一、什么是分层架构分层体系结构主要是根据水平分割将软件模块划分为多个层次。
系统由多层组成,每一层由多个模块组成。
那么多少层才是合适的呢?IT培训认为,根据不同的复杂性分为不同的层次,基本的层次结构是三个层次,即表示层、域层和数据持久层。
二、分层架构的好处1、单一职责:每层只负责一个角色,责任边界清晰。
如果持久层只负责数据查询和存储,则字段级别仅负责处理业务逻辑。
2、高内聚:分层是在相同的层中放置相同的责任,并且所有业务逻辑在领域层中都是一致的。
做这个的好处是什么?江西北大青鸟设想如果业务逻辑分散在每层上,则修改功能需要修改为各层,测试业务逻辑需要测试所有层的代码,从而增加了整个软件的复杂度和测试难度。
3、易维护将面对变更且容易修正的所有对外界面放入对外界面层中,如果外部依存的界面被修改的话,只要变更该层的代码即可。
三、分层架构的缺点1、开发成本高由于多层承担着各自的任务,因此需要在多个级别上追加代码,以添加功能。
这样,开发成本就会增加。
但是,北大青鸟认为合理的能力抽象化可以提高多重性,降低开发成本。
2、可扩展性低:由于在上下层之间存在结合度,所以所有的功能变化都有可能参与多层的修正。
网站标题:Java代码层次结构 java代码分层原理
标题链接:http://scpingwu.com/article/dohpcjd.html