什么是基于spring框架的设计,基于spring框架的设计究竟有什么用呢?我们可以用基于spring框架的设计来做些什么呢?这是我今天要说的内容。
当然,百度基于spring框架的设计会出现一大堆基于spring框架的设计的介绍,以及IOC和AOP。但是这些官方的语言,看书都有解释,关键是我不知道为什么要用基于spring的设计,基于spring框架的设计和不用框架到底区别在哪,还有它到底是通过什么来表明我用的框架就是基于spring框架的设计的?
基于spring的设计很抽象,基于spring的设计是框架,框架的主要目的是什么呢?大概所有框架的目的都一样吧,那就是简化开发。而它存在的目的也是为了简化java开发。
它是怎样来简化开发的呢?让我们看看基于spring的设计采取的关键策略。
基于POJO的轻量级和最小侵入性编程;
通过依赖注入和面向接口实现松耦合;
基于切面和惯例进行声明式编程;
通过切面和模板减少样板式代码。
这就是基于spring框架的设计的四种关键策略。我们下面详细谈谈。
基于spring框架的设计的最小侵入性
基于spring的设计竭力避免因自身的API而弄乱你的应用代码。 基于spring的设计不会强迫你实现基于spring的设计规范的接口或继承基于spring的设计规范的类, 相反, 在基于基于spring的设计构建的应用中, 它的类通常没有任何痕迹表明你使用了基于spring的设计。只能通过xml配置文件来看出基于spring的设计的思想。
最坏的场景是,一个类或许会使用基于spring的设计注解, 但它依旧是POJO。
那可能有人要问了,不侵入如何实现基于spring框架的设计强大的功能,基于spring框架的设计不是很强大吗?在这里我要说明,基于spring框架的设计是很强大,但它的强大在于它的理念,它的思想,而不是它实现了多强大的功能。
当然不侵入有不侵入的解决方法,在我的理解里它的解决方法也算是基于spring的设计的核心吧!那就是配置文件或者注解。
让我们来看一个javabean。它是一个普通的java类。
public class exampleBean(){
public String testPrint(){
System.out.println("===test===");}
}基于spring的设计的非入侵式就是不强制类要实现基于spring的设计的任何接口或类,没有任何地方表明它是一个基于spring的设计组件。 意味着这个类在基于spring的设计应用和非基于spring的设计应用中都可以发挥同样的作用。
那这个类在不耦合的情况下是如何发挥作用的呢?这就要提到基于spring框架的设计的DI(依赖注入)了。
依赖注入
任何一个有实际意义的应用都会由两个或者更多的类组成,这些类相互之间进行协作来完成特定的业务逻辑。按照传统的做法,每个对象负责管理与自己相互协作的对象(即它所依赖的对象)的引用,这将会导致高度耦合和难以测试的代码。而基于spring框架的设计利用依赖注入恰恰解决了这一难题。
耦合具有两面性。一方面,紧密耦合的代码难以测试、难以复用、难以理解,并且典型地表现出“打地鼠”式的bug特性 。 另一方面, 一定程度的耦合又是必须的——完全没有耦合的代码什么也做不了。 为了完成有实际意义的功能, 不同的类必须以适当的方式进行交互。 总而言之, 耦合是必须的, 但应当被小心谨慎地管理。
public void DealData(){
public Data data;
public void setData(Data data){
this.data=data;
}
public void add(){
data.add();
}
}
如上图,DealData类和Data类耦合了。
通过DI, 对象的依赖关系将由系统中负责协调各对象的第三方组件在创建对象的时候进行设定。 对象无需自行创建或管理它们的依赖关系。
应用切面
DI能够让相互协作的软件组件保持松散耦合,而面向切面编程(aspect-oriented programming, AOP) 允许你把遍布应用各处的功能分离出来形成可重用的组件。
面向切面编程往往被定义为促使软件系统实现关注点的分离一项技术。系统由许多不同的组件组成,每一个组件各负责一块特定功能。除了实现自身核心的功能之外,这些组件还经常承担着额外的职责。诸如日志、事务管理和安全这样的系统服务经常融入到自身具有核心业务逻辑的组件中去,这些系统服务通常被称为横切关注点,因为它们会跨越系统的多个组件。
如果将这些关注点分散到多个组件中去,你的代码将会带来双重的复杂性。
实现系统关注点功能的代码将会重复出现在多个组件中。这意味着如果你要改变这些关注点的逻辑,必须修改各个模块中的相关实现。
即使你把这些关注点抽象为一个独立的模块,其他模块只是调用它的方法,但方法的调用还是会重复出现在各个模块中。
组件会因为那些与自身核心业务无关的代码而变得混乱。一个向地址簿增加地址条目的方法应该只关注如何添加地址,而不应该关注它是不是安全的或者是否需要支持事务
图1.2展示了这种复杂性。 左边的业务对象与系统级服务结合得过于紧密。 每个对象不但要知道它需要记日志、 进行安全控制和参与事务, 还要亲自执行这些服务。
在整个系统内,关注点(例如日志和安全)的调用经常散布到各个模块中,而这些关注点并不是模块的核心业务
AOP能够使这些服务模块化,并以声明的方式将它们应用到它们需要影响的组件中去。所造成的结果就是这些组件会具有更高的内聚性并且会更加关注自身的业务,完全不需要了解涉及系统服务所带来复杂性。总之,AOP能够确保POJO的简单性。
我们可以把切面想象为覆盖在很多组件之上的一个外壳。应用是由那些实现各自业务功能的模块组成的。借助AOP, 可以使用各种功能层去包裹核心业务层。 这些层以声明的方式灵活地应用到系统中, 你的核心应用甚至根本不知道它们的存在。 这是一个非常强大的理念, 可以将安全、 事务和日志关注点与核心业务逻辑相分离。
我们是专业做JAVA毕设定制的,区别于某宝上的成品, 我们是代做+讲解,全程协助你选题以及代写你的设计程序部分。可以先给你做,看了满意后才付款的哦。
流程:
一沟通分析(按照开题思路沟通设计、完成开题报告)
二确认方案(编写代码,本店特色每行代码实现的功能你不懂的可讲解)
三完成20%(完成一部分给看效果)
四完成100%(验收交货)
五售后(导师提修改意见可进行修改)
六设计可全篇讲解(需要一对一讲解详询客服)
七答辩指导(最终完成毕业答辩)
我们是做专业定制的团队,我们的老师人都非常好。有需要的同学可以ADD me,My Q-Q number is one--zero-three-two-three-seven-one-two-one。
至于毕业设计的论文,格式,字数,查重,就这些要求我们会给你讲方法。只要你按照方法去做都可以完成。
利用AOP, 系统范围内的关注点覆盖在它们所影响组件之上
为了示范在基于spring的设计中如何应用切面, 让我们重新回到骑士的例子, 并为它添加一个切面。
每一个人都熟知骑士所做的任何事情,这是因为吟游诗人用诗歌记载了骑士的事迹并将其进行传唱。假设我们需要使用吟游诗人这个服务类来记载骑士的所有事迹。程序清单1.9展示了我们会使用的Minstrel类。我们的团队都是多年开发经验的老师,另可承接各中小系统程序开发项目。
给大家推荐部分2021年最新选题:
基于SSM框架的疫情防控管理系统
基于SSM框架的社区疫情管理系统
基于SSM框架的小区防疫管理系统
基于SSM框架的农贸信息化管理平台
基于SSM框架的大学生创业项目管理平台
基于SSM框架的幼儿托管服务管理系统
基于SSM框架的废品回收管理系统
基于SSM框架的校园疫情防控管理系统
基于SSM框架的校园疫情防控管理系统
基于SSM框架物流管理系统
基于SSM框架网络资产管理系统
基于SSM框架网络硬盘管理系统
基于SSM框架股份管理系统
基于SSM框架学校比赛赛事管理系统
基于SSM框架进销存管理系统
基于SSM框架影碟管理系统
基于SSM框架旅游景点管理系统
基于SSM框架客户关系管理系统
基于SSM框架客户服务管理系统
基于SSM框架学校机构管理系统
基于SSM框架固定资产管理系统
基于SSM医院门诊住院管理系统
基于SSM学生公寓管理系统
基于SSM酒店住宿管理系统
基于SSM BBS论坛
基于SSM个人博客
基于SSM药房药库管理
基于SSM公司会议室管理系统
基于SSM房地产销售管理系统
基于SSM物业管理系统
基于SSM销售管理系统
基于SSM医院药品管理系统
基于SSM房屋出租管理系统
基于JAVA的超市管理系统
基于JAVA的网上购物系统
基于JAVA的物流管理系统
基于JAVA的汽车租赁管理系统
基于JAVA的点菜管理系统
基于JAVA的招聘求职管理系统
基于JAVA的代做网络资产管理系统
基于JAVA的家政管理系统
基于JAVA的 企业管理系统
基于JAVA的网络硬盘系统
基于JAVA的医院门诊管理系统
基于JAVA的药店进销存管理系统
基于JAVA的人力资源管理系统
基于JAVA的进存销管理系统
基于JAVA的新闻发布系统
基于JAVA的商品交易管理系统
基于JAVA的博客管理系统
基于JAVA的网上书城管理系统
基于JAVA的客户满意管理系统
基于JAVA的教务管理系统
基于JAVA的图书管理系统
基于JAVA的物流仓储管理系统
基于JAVA的租车管理系统
基于JAVA的聊天室管理系统