1. TypeReference
使用fastJson反序列化的时候用到
为什么使用TypeReference
浅谈FastJson的TypeReference用法
2. MoreObjects.firstNonNull
返回第一个不为空的对象
Guava base -- MoreObjects
3. RowBounds
逻辑分页。之前一直没有注意,还以为最后也是limit,结果查资料后发现是逻辑分页,即取出所有满足条件的数据,然后舍弃掉前面offset条数据,然后再取剩下的数据的limit条
mybatis 分页 RowBounds和PageHelper性能评测
Mybatis逻辑分页原理解析RowBounds
4. @ApiOperation
接口文档注解,用于生成对应的接口文档,是swagger注解
spring接口文档注解:@ApiOperation
5. @JsonNaming注解
与PropertyNamingStrategy结合,项目中用到的是PropertyNamingStratgey.SnakeCaseStrategy,之后代码中的驼峰命名会转变为下划线。
Sping Boot返回Json格式自定义
6. PageHelper
项目中使用了PageHelper插件,需要注意的是spring boot项目引用的 版本是不同的
pagehelper-spring-boot-starter
7. @Transactional
该注解只能被用到public方法上。
其他的目前还没有注意到,等后续踩坑。
@Transactional详解
8. @ResponseBody @ResquestBody
@ResponseBody作用在方法上,表示该方法的返回结果直接写入Http response body中,一般在异步获取数据时使用ajax,在使用@RequestMapping之后,返回值会被解析为跳转路径,加入@ResponseBody注解后,返回结果不会被解析为跳转路径,而是直接写入response body中。
@RequestBody将Http请求正常插入到方法中,使用合适的HttpMessageConverter将请求体写入某个对象。
注解@ResponseBody和@RequestBody
@Controller和@RestController的区别?
9. @NoArgsConstructor @RequiredArgsConstructor @AllArgsConstructor
@RequiredArgsConstructor, @AllArgsContructor。使用这三个annotation来完成项目中对于不同构造方法的需求。
@NoArgsConstructor : 生成一个无参数的构造方法,这个annotation在与其他的annotation配合起来使用的时候更加能凸显出他的重要性,例如在使用hibernate这种框架的时候,如果有一个有参数的构造方法的时候,NoArgsConstructor会展示出他的作用。
@RequiredArgsConstructor: 会生成一个包含常量,和标识了NotNull的变量 的构造方法。生成的构造方法是private,如何想要对外提供使用可以使用staticName选项生成一个static方法。
@AllArgsContructor: 会生成一个包含所有变量,同时如果变量使用了NotNull annotation , 会进行是否为空的校验。
@NoArgsConstructor, @RequiredArgsConstructor, @AllArgsConstructor
10. @EnableScheduling
@Scheduled注解配合@EnableScheduling使用,实现定时任务。
Spring @EnableScheduling 注解解析