zoukankan      html  css  js  c++  java
  • Spring Framework 5.0 新特性

    Spring Framework 5.0 是自 2013年12月版本 4 发布之后 Spring Framework 的第一个主发行版。Spring Framework 项目的领导人 Juergen Hoeller 于 2016 年 7 月 28 日宣布了第一个 Spring Framework 5.0 里程碑版本(5.0 M1)。

    现在,将近一年的时间过去以后,我们期盼已久的 RC3 版本将于 2017 年 7 月 18 日发行。这是路线图规划中 Spring Framework 5.0 首个 GA 发行版的最后一次发行。

    从高层来看,Spring Framework 5.0 的功能可以分为:

    • JDK 基线更新

    • 核心框架修正

    • 核心容器更新

    • 含 Kotlin 在内的函数式编程

    • 响应式编程模型

    • 测试改进

    • 库支持

    • 中止支持

    Spring Framework 5.0 的 JDK 基线更新

    整个 Spring framework 5.0 代码库运行于 Java 8 之上。因此 Spring Framework 5.0 对环境的最低要就就是 Java 8。

    这一点实际上对框架而言非常重要。而作为开发者的我们而言,则已经能够去藉此来享受到现代 Java 发行版中的所有新特性了。而框架版本还背负这支持已经不被建议使用的 Java 发行版的任务。

    现在,框架的最低要求是 Java 8.

    Spring Framework 5.0 原来是计划在 Java 9 之上发行的。然后,在基于 Java 9 的发行版运作了超过 18 个月之后, Spring 团队决定将 Spring Framework 5.0 发行版同 Java 9 的绑定关系解除。

    不过,在 Java 9 发布的时候(计划是2017年9月份), Spring Framework 5.0 会准备好的。

    核心框架修订

    核心的 Spring Framework 5.0 已经利用 Java 8 所引入的新特性进行了修订。比较关键的一些如下:

    • 基于 Java 8 的反射增强,  Spring Framework 5.0 中的方法参数可以更加高效的进行访问。

    • 核心的 Spring 接口现在提供基于Java 8 的默认方法构建的选择性声明。

    • 用 @Nullable 和 @NotNull 注解来显示表明可为空的参数和以及返回值。这样就够在编译的时候处理空值而不是在运行时抛出 NullPointerExceptions。

    在日志记录方面, Spring Framework 5.0 带来了 Commons Logging 桥接模块的封装, 它被叫做 spring-jcl 而不是标准的 Commons Logging。当然,无需任何额外的桥接,新版本也会对 Log4j 2.x, SLF4J, JUL ( java.util.logging) 进行自动检测。

    有了 Resourse 抽象所提供的 isFile 指示器以及 getFile 方法,防御式编程方法也得到了框架的推动。

    核心容器更新

    Spring Framework 5.0 现在支持候选组件索引作为类路径扫描的替代方案。该功能已经在类路径扫描器中添加,以简化添加候选组件标识的步骤。

    应用程序构建任务可以定义当前项目自己的 META-INF/spring.components 文件。在编译时,源模型是自包含的,JPA 实体和 Spring 组件是已被标记的。

    从索引读取实体而不是扫描类路径对于小于 200 个类的小型项目是没有明显差异。但对大型项目影响较大。加载组件索引开销更低。因此,随着类数的增加,索引读取的启动时间将保持不变。

    加载组件索引的耗费是廉价的。因此当类的数量不断增长,加上构建索引的启动时间仍然可以维持一个常数, 不过对于组件扫描而言,启动时间则会有明显的增长。

    这个对于我们处于大型 Spring 项目的开发者所意味着的,是应用程序的启动时间将被大大缩减。虽然 20 或者 30 秒钟看似没什么,但如果每天要这样登上好几百次,加起来就够你受的了。使用了组件索引的话,就能帮助你每天过的更加高效。

    你可以在 Spring 的 Jira上了解更多关于组件索引的相关信息。

    @Nullable 注解现在也可以被用来作为可选注入项的指示器。@Nullable 为对象使用方规定了一项义务,就是它们必须准备以为取值为 null 的值。在此次发布之前,实现这件事情的唯一方法就是通过 Android 的 NullableChecker Framework 的 Nullable, 以及 JSR 305 的 Nullable

    发行说明中的其他一些新功能和增强功能包括:

    • 在 GenericApplicationContext 和 AnnotationConfigApplicationContext 中实现函数式编程风格。

    • 对接口方法的事务、缓存和异步注释的一致性检测。

    • 将 XML 配置命名空间简化为无版本化的模式。

    使用 Kotlin 进行函数式编程

    Spring Framework 5.0 引入了对 JetBrains Kotlin 语言的支持。Kotlin 是一种支持函数式编程编程风格的面向对象语言。Kotlin 运行在 JVM 之上,但运行环境并不限于 JVM。

    有了对 Kotlin 的支持,开发者可以进行深度的函数式 Spring 编程,特别是在函数式 Web 端点以及 Bean 注册这些方面。

    在 Spring Framework 5.0 中, 你可以为 WEB 的函数式 API 编写干净且地道的 Kotlin 代码,就像下面这样:

    01 {
    02 ("/movie" and accept(TEXT_HTML)).nest {
    03 GET("/", movieHandler::findAllView)
    04 GET("/{card}", movieHandler::findOneView)
    05 }
    06 ("/api/movie" and accept(APPLICATION_JSON)).nest {
    07 GET("/", movieApiHandler::findAll)
    08 GET("/{id}", movieApiHandler::findOne)
    09 }
    10 }

    对于 Bean 的注册,作为 XML 或者 @Configuration 以及 @Bean 的替代办法, 现在你可以使用 Kotlin 来注册 Spring Bean了,就像下面这样:

    1 val context = GenericApplicationContext {
    2 registerBean()
    3 registerBean { Cinema(it.getBean()) }
    4 }

    点击这里了解我的新的 Spring Framework 5 课程的相关信息!

    响应式编程模型

    此次 Spring 发行版本的一个激动人心的特性就是新的响应式堆栈 WEB 框架。这个堆栈完全的响应式且非阻塞,适合于事件循环风格的处理,可以进行少量线程的扩展。

    Reactive Streams 是来自于 Netflix, Pivotal, Typesafe, Red Hat, Oracle, Twitter 以及 Spray.io 的工程师特地开发的一个 API。它为响应式编程实现的实现提供一个公共的 API,好实现 Hibernate 的 JPA。这里 JPA 就是这个 API, 而 Hibernate 就是实现。

    Reactive Streams API 是 Java 9 的官方版本的一部分。在 Java 8 中, 你会需要专门引入依赖来使用 Reactive Streams API。

    Spring Framework 5.0 对于流式处理的支持依赖于 Project Reactor 来构建, 其专门实现了 Reactive Streams API。

    Spring Framework 5.0 拥有一个新的 spring-webflux 模块,支持响应式 HTTP 和 WebSocket 客户端。Spring Framework 5.0 还提供了对于运行于服务器之上,包含了 REST, HTML, 以及 WebSocket 风格交互的响应式网页应用程序的支持。

    在 spring-webflux 中包含了两种独立的服务端编程模型:

    • 基于注解:使用到了@Controller 以及 Spring MVC 的其它一些注解;

    • 使用 Java 8 lambda 表达式的函数式风格的路由和处理。

    有了 Spring Webflux, 你现在可以创建出 WebClient, 它是响应式且非阻塞的,可以作为 RestTemplate 的一个替代方案。

    这里有一个使用 Spring 5.0 的 REST 端点的 WebClient 实现:

    1 WebClient webClient = WebClient.create();
    2 Mono person = webClient.get()
    3 .uri("http://localhost:8080/movie/42")
    4 .accept(MediaType.APPLICATION_JSON)
    5 .exchange()
    6 .then(response -> response.bodyToMono(Movie.class));

    尽管新的 WebFlux 模块给我么带来了激动人心的新能力,传统的 Spring MVC 在  Spring Framework 5.0 仍然得到了完整的支持。

    测试方面的提升

    Spring Framework 5.0 完全支持 JUnit 5 Jupiter,所以可以使用 JUnit 5 来编写测试以及扩展。此外还提供了一个编程以及扩展模型,Jupiter 子项目提供了一个测试引擎来在 Spring 上运行基于 Jupiter 的测试。

    另外,Spring Framework 5 还提供了在 Spring TestContext Framework 中进行并行测试的扩展。

    针对响应式编程模型, spring-test 现在还引入了支持 Spring WebFlux 的 WebTestClient 集成测试的支持,类似于 MockMvc,并不需要一个运行着的服务端。使用一个模拟的请求或者响应, WebTestClient 就可以直接绑定到 WebFlux 服务端设施。

    你可以在这里找到这个激动人心的 TestContext 框架所带来的增强功能的完整列表。

    当然, Spring Framework 5.0 仍然支持我们的老朋友 JUnit! 在我写这篇文章的时候, JUnit 5 还只是发展到了 GA 版本。对于 JUnit4, Spring Framework 在未来还是要支持一段时间的。

    库支持

    Spring Framework 5.0目前支持以下升级库的版本 :

    中止的支持

    在 API 层面,Spring Framework 5.0 不再支持以下包:

    • beans.factory.access 

    • jdbc.support.nativejdbc 

    • spring-aspects 模块的 mock.staticmock

    • web.view.tiles2M.(最低要求 Tiles 3)

    • orm.hibernate3 和 orm.hibernate4. 目前 Hibernate 5 是支持的框架。

    Spring Framework 5.0 同时也停止了对以下库的支持:

    如果你正在使用任何上面的包,建议你将 Spring Framework 版本维持在 4.3.x。

    结语

    Spring Framework 5.0 的亮点绝对是响应式编程,这是一个重要的范式转变。你可以将 Spring Framework 5.0 作为响应式程序的基础版本。对于 2017 年及以后的剩余时间里,你可以期待看到子项目实现响应式特性。你将看到即将发布的 Spring Data、Spring Security、Spring Integration 等版本所提供的响应式编程功能。

    Spring Data 团队已经为 MongoDB 和 Redis 实现了响应式支持。

    使用 JDBC 获取响应式支持还为时过早。JDBC 规范本身就是阻塞的,在传统的 JDBC 数据库中看到响应式编程的还需要一段时间。

    虽然响应式编程是 Spring Framework 5.0 中的闪光点,但它不会在任何地方得到支持。 下游技术需要提供响应式支持。

    随着响应式编程越来越受欢迎,我们可以期待越来越多的技术将实现响应式解决方案。 当然,我们可以期待 Spring 框架随着其他的响应式编程方案的使用而发展。

  • 相关阅读:
    Unity3D使用OpenFileDialog后崩溃
    JS定时器
    如果把我剥得一文不名丢在沙漠的中央,只要一行驼队经过———我就可以重建整个商业帝国
    软件开发架构
    C#对象序列化与反序列化
    我的作品们
    fread 不能读取最后一个数据块
    for循环中的i++和++i
    MOS管不能关断的原因!!!
    AD16 快速原理图封装导出
  • 原文地址:https://www.cnblogs.com/interdrp/p/7610634.html
Copyright © 2011-2022 走看看