1.整个Spring5框架的代码基于Java8开发,运行时兼容jdk9,许多不建议使用的类和方法在代码库中删除
2.Spring5.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)@Nullable 用在方法上,表示方法的返回值可以为空
(3)@Nullable使用方法参数里面,方法的参数可以为为空
(4)注解使用在属性上面,属性值可以为空
4.Spring5核心容器支持函数式风格GenericApplicationContext
//函数式风格创建对象,交给Spring进行管理
@Test
public void test3() {
//1.创建GenericApplicationContext对象
GenericApplicationContext context = new GenericApplicationContext();
//2.调用context的方法惊醒对象注册
context.refresh();
context.registerBean("user1",User.class,()-> new User());
//3.获取在spring中注册的对象
// User user = (User) context.getBean("org.example.spring5.test.User");
User user1 = (User) context.getBean("user1");
System.out.println(user1);
}
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")
//第二种方法
@SpringJUnitConfig(locations = "classpath:bean1.xml")
public class JTest5 {
@Autowired
private UserService userService;
@Test
public void test1() {
userService.accountMoney();
}
}
6.SpringWebFlux
0.前置知识
SpringMVC,SpringBoot,Maven, Java8新特性
1.springWebflux介绍
(1)是Spring5添加新的模块,用于web开发的,功能与SprngMVC类似,WebFlux使用当前一种比较流行的响应式编程出现的框架。
(2)使用传统web框架,比如SpringMVC,这些基于Servlet容器,WebFlux是一种异步非阻塞的框架,异步非阻塞的框架在Servlet3.1以后才支持,核心是居于Reactor的相关API实现的。
(3)什么是异步非阻塞
- 异步和同步
- 阻塞非阻塞
上面都是针对对象不一样
异步和同步针对调用者,调用者发送请求,如果等着对方回应之后才去做其他事情就是同步。如果发送请求之后不等对方回应就去做其他事情就是异步。
阻塞和非阻塞针对被调用者,被调用者收到请求之后,做完请求任务之后才给出反馈就是阻塞。受到请求后马上给出反馈然后再去做事情就是非阻塞。
(4)webflux特点:
第一、非阻塞式:在有限的资源下,提高系统的吞吐量和伸缩性,以Reactor为基础实现响应式编程。
第二、函数式编程:Spring5框架就是基于java8,webFlux使用java8函数式编程实现路由请求。
(5) 比较springMVC
第一、两个框架都可以使用注解方式操作,都可以运行在tomcat等容器中
第二、SpringMVC采用命令式编程,WebFlux采用异步响应式编程
2.响应式编程RP(Reactive Programming)
(1)什么是响应式编程?
响应式编程是一种面向数据流和变化传播的编程范式。这意味着可以在编程语言中很方便地表达静态或动态的数据流,而相关的计算模型会自动将变化的值通过数据流进行传播。
电子表格程序就是响应式编程的一个例子。单元格可以包含字面值或类似"=B1+C1"的公式,而包含公式的单元格的值会依据其他单元格的值的变化而变化。
(2)Java8及其之前版本
java8提供了观察者模式两个类Observer和obeservable
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();//通知
}
}
响应式编程(Reactor实现)
(1)响应式编程操作中,Reactor是满足Reactive规范框架。
(2)Reactor有两个核心类,Mono和Flux,这个两个类接口Publisher,提供丰富操作符。Flux对象实现发布者,返回N个元素;Mono实现发布者,返回0或者1个元素。
(3)Flux和Mono都是数据流的发布者,使用Flux和mono都可以发出三种数据信号:元素值,错误信号,完成信号。错误信号和完成信号都代表终止信号,终止信号用于告诉订阅者数据流结束了。错误信号种植数据流同时把错误信息传递给订阅者。
(4)代码演示Flux和Mono
第一步:引入依赖reactor
<dependency>
<groupId>io.projectreactor</groupId>
<artifactId>reactor-core</artifactId>
</dependency>
第二步:编写代码
public class TestReactor {
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)三种信号特点
错误信号和完成信号都是终止信号,不能共存。
如果没有发送任何元素值,而是直接发送错误或完成信号,表示是空的数据流
如果没有错误信号或完成信号,表示是无限数据流
3.Webflux执行流程和核心API
4.SpringWebflux(基于注解编程模型)
5.SpringWebflux(基于函数式编程模型)