龙空技术网

尚硅谷Spring学习笔记(6)——Spring5新功能

java小李子 207

前言:

而今咱们对“尚硅谷java基础笔记”大体比较关心,朋友们都想要知道一些“尚硅谷java基础笔记”的相关文章。那么小编也在网络上收集了一些关于“尚硅谷java基础笔记””的相关内容,希望兄弟们能喜欢,你们快快来了解一下吧!

一、Spring5 框架新功能1、整个 Spring5 框架的代码基于 Java8,运行时兼容 JDK9,许多不建议使用的类和方

法在代码库中删除

2、Spring 5.0 框架自带了通用的日志封装 (1)Spring5 已经移除 Log4jConfigListener,官方建议使用 Log4j2

(2)Spring5 框架整合 Log4j2 第一步 引入 jar 包

第二步 创建 log4j2.xml 配置文件

<?xml version="1.0" encoding="UTF-8"?><!--日志级别以及优先级排序: OFF > FATAL > ERROR > WARN > INFO > DEBUG > TRACE > ALL --><!--Configuration 后面的 status 用于设置 log4j2 自身内部的信息输出,可以不设置,当设置成 trace 时,可以看到 log4j2 内部各种详细输出--> <configuration status="INFO"> <!--先定义所有的 appender--> <appenders> <!--输出日志信息到控制台--> <console name="Console" target="SYSTEM_OUT"> <!--控制日志输出的格式--> <PatternLayout pattern="%d{yyyy-MM-dd HH:mm:ss.SSS} [%t] %-5level %logger{36} - %msg%n"/> </console> </appenders> <!--然后定义 logger,只有定义 logger 并引入的 appender,appender 才会生效--> <!--root:用于指定项目的根日志,如果没有单独指定 Logger,则会使用 root 作为默认的日志输出--> <loggers> <root level="info"> <appender-ref ref="Console"/> </root> </loggers></configuration>复制代码
3、Spring5 框架核心容器支持@Nullable 注解

(1)@Nullable 注解可以使用在方法上面,属性上面,参数上面,表示方法返回可以为空,属性值可以 为空,参数值可以为空 (2)注解用在方法上面,方法返回值可以为空

(3)注解使用在方法参数里面,方法参数可以为空

(4)注解使用在属性上面,属性值可以为空

4、Spring5 核心容器支持函数式风格 GenericApplicationContext

//函数式风格创建对象,交给 spring 进行管理@Testpublic void testGenericApplicationContext() {    //1 创建 GenericApplicationContext 对象    GenericApplicationContext context = new GenericApplicationContext();    //2 调用 context 的方法对象注册    context.refresh();    context.registerBean("user1",User.class,() -> new User());    //3 获取在 spring 注册的对象    // User user = (User)context.getBean("com.atguigu.spring5.test.User");    User user = (User)context.getBean("user1");    System.out.println(user);}复制代码
5、Spring5 支持整合 JUnit5

(1)整合 JUnit4 第一步 引入 Spring 相关针对测试依赖

第二步 创建测试类,使用注解方式完成

@RunWith(SpringJUnit4ClassRunner.class) //单元测试框架@ContextConfiguration("classpath:bean1.xml") //加载配置文件public class JTest4 {	@Autowired	private UserService userService;	@Test	public void test1() {	   userService.accountMoney();	}}复制代码

(2)Spring5 整合 JUnit5 第一步 引入 JUnit5 的 jar 包

第二步 创建测试类,使用注解完成

@ExtendWith(SpringExtension.class)@ContextConfiguration("classpath:bean1.xml")public class JTest5 {	 @Autowired	 private UserService userService;	 @Test	 public void test1() {	 userService.accountMoney();	 }}复制代码

(3)使用一个复合注解替代上面两个注解完成整合

@SpringJUnitConfig(locations = "classpath:bean1.xml")public class JTest5 {	 @Autowired	 private UserService userService;	 @Test	 public void test1() {	 userService.accountMoney();	 }}复制代码
二、Spring5 框架新功能(Webflux)1、SpringWebflux 介绍

(1)是 Spring5 添加新的模块,用于 web 开发的,功能和 SpringMVC 类似的,Webflux 使用 当前一种比较流程响应式编程出现的框架。

(2)使用传统 web 框架,比如 SpringMVC,这些基于 Servlet 容器,Webflux 是一种异步非阻 塞的框架,异步非阻塞的框架在 Servlet3.1 以后才支持,核心是基于 Reactor 的相关 API 实现 的。 (3)解释什么是异步非阻塞

异步和同步非阻塞和阻塞

** 上面都是针对对象不一样

** 异步和同步针对调用者,调用者发送请求,如果等着对方回应之后才去做其他事情就是同 步,如果发送请求之后不等着对方回应就去做其他事情就是异步 ** 阻塞和非阻塞针对被调用者,被调用者受到请求之后,做完请求任务之后才给出反馈就是阻 塞,受到请求之后马上给出反馈然后再去做事情就是非阻塞 (4)Webflux 特点: 第一 非阻塞式:在有限资源下,提高系统吞吐量和伸缩性,以 Reactor 为基础实现响应式编程 第二 函数式编程:Spring5 框架基于 java8,Webflux 使用 Java8 函数式编程方式实现路由请求 (5)比较 SpringMVC

第一 两个框架都可以使用注解方式,都运行在 Tomet 等容器中第二 SpringMVC 采用命令式编程,Webflux 采用异步响应式编程

2、响应式编程(Java 实现)

(1)什么是响应式编程 响应式编程是一种面向数据流和变化传播的编程范式。这意味着可以在编程语言中很方便 地表达静态或动态的数据流,而相关的计算模型会自动将变化的值通过数据流进行传播。 电子表格程序就是响应式编程的一个例子。单元格可以包含字面值或类似"=B1+C1"的公 式,而包含公式的单元格的值会依据其他单元格的值的变化而变化。 (2)Java8 及其之前版本

提供的观察者模式两个类 Observer 和 Observable

public class ObserverDemo extends Observable { public static void main(String[] args) {	 ObserverDemo observer = new ObserverDemo();	 //添加观察者	 observer.addObserver((o,arg)->{	 System.out.println("发生变化");	 });	 observer.addObserver((o,arg)->{	 System.out.println("手动被观察者通知,准备改变");	 });	 observer.setChanged(); //数据变化	 observer.notifyObservers(); //通知	 }}复制代码
3、响应式编程(Reactor 实现)

(1)响应式编程操作中,Reactor 是满足 Reactive 规范框架 (2)Reactor 有两个核心类,Mono 和 Flux,这两个类实现接口 Publisher,提供丰富操作 符。Flux 对象实现发布者,返回 N 个元素;Mono 实现发布者,返回 0 或者 1 个元素 (3)Flux 和 Mono 都是数据流的发布者,使用 Flux 和 Mono 都可以发出三种数据信号: 元素值,错误信号,完成信号,错误信号和完成信号都代表终止信号,终止信号用于告诉 订阅者数据流结束了,错误信号终止数据流同时把错误信息传递给订阅者

(4)代码演示 Flux 和 Mono 第一步 引入依赖

<dependency>	<groupId>io.projectreactor</groupId>	<artifactId>reactor-core</artifactId>	<version>3.1.5.RELEASE</version></dependency>复制代码

第二步 编程代码

public static void main(String[] args) {	//just 方法直接声明	Flux.just(1,2,3,4);	Mono.just(1);	//其他的方法	Integer[] array = {1,2,3,4};	Flux.fromArray(array);		List<Integer> list = Arrays.asList(array);	Flux.fromIterable(list);	Stream<Integer> stream = list.stream();	Flux.fromStream(stream);}复制代码

(5)三种信号特点

错误信号和完成信号都是终止信号,不能共存的如果没有发送任何元素值,而是直接发送错误或者完成信号,表示是空数据流如果没有错误信号,没有完成信号,表示是无限数据流

(6)调用 just 或者其他方法只是声明数据流,数据流并没有发出,只有进行订阅之后才会触发数据流,不订阅什么都不会发生的

标签: #尚硅谷java基础笔记