您的位置:首页 > 编程语言 > Java开发

Spring Boot2.0之@Async实现异步调用

2018-10-19 20:56 330 查看

 补充一个知识点:

lombok底层原理使用的是: 字节码技术ASM修改字节码文件,生成比如类似于get() set( )方法

一定要在开发工具安装 在编译时候修改字节码文件(底层使用字节码技术),线上环境使用编译好的文件

 

下面我们学习 Spring Boot 异步调用技术:

启动加上@EnableAsync ,需要执行异步方法上加入    @Async

在方法上加上@Async之后 底层使用多线程技术

在底层实际上是帮助创建线程了 

首先创建类:MembrController

package com.toov5.jsp;

import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.web.bind.annotation.RestController;

import com.toov5.service.MemberService;

import lombok.extern.slf4j.Slf4j;

@RestController
@Slf4j
public class MemberController {
@Autowired
private MemberService memberService;

public String addMemberAndEmail(){
log.info("1");
String result = memberService.addMemberAndEmail();
log.info("4");
return result;
}

}

MemberService

package com.toov5.service;

import org.springframework.stereotype.Service;

import lombok.extern.slf4j.Slf4j;

@Service
@Slf4j
public class MemberService {
//添加用户时候发送邮件
public String addMemberAndEmail(){
log.info("2");
try {
Thread.sleep(5000);
} catch (Exception e) {
// TODO: handle exception
}
log.info("3");
return "toov5";

}

}

我们做个分析:

这个项目是没有开线程的情况下的,代码从上往下同步进行的,log输出结果就是1 2 3 return返回结果  4 然后返回结果 

看结果:

 

先输出1 2  然后 五秒 后 3  4  效果是同步的

下面隆重接受一个注解

@Async 相当于这个方法重新开辟了新的线程去执行

 

然后启动类一定要加上启动的注解!!!@EnableAsync

 

 加上 @EnableAsync看看指定的包里面  有哪些加了@Asyn注解 加了的在运行时候通过AOP技术,创建线程去执行

执行结果:

controller的代码这样:

package com.toov5.jsp;

import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;

import com.toov5.service.MemberService;

import lombok.extern.slf4j.Slf4j;

@RestController
@Slf4j
public class MemberController {
@Autowired
private MemberService memberService;

@RequestMapping("/addMemberAndEmail")
public String addMemberAndEmail(){
log.info("1");
String result = memberService.addMemberAndEmail();
log.info("4");
return "result"+result;
}

}

结果:

 

 结果值是没有拿到 主线程就后已经结束了哈 所以为 null

 

原理思路:

使用AOP技术,在运行时候 创建单独线程进行执行 

可以这么代替:

package com.toov5.service;

import org.springframework.stereotype.Service;

import lombok.extern.slf4j.Slf4j;

@Service
@Slf4j
public class MemberService {
//添加用户时候发送邮件
//	@Async
//	public String addMemberAndEmail(){
//		log.info("2");
//		try {
//			Thread.sleep(5000);
//		} catch (Exception e) {
//			// TODO: handle exception
//		}
//		log.info("3");
//		return "toov5";
//
//	}

public String addMemberAndEmail(){

new Thread(new Runnable() {

public void run() {

log.info("2");
try {
Thread.sleep(5000);
} catch (Exception e) {
// TODO: handle exception
}
log.info("3");
//			return "toov5";  //这里应该用从callable  有返回值 或者future模式

}
}).start();

return "toov5";  //将就下 返回值由于是用的runnable写的嘛 先这样迁就下

}

}

 效果:

 

 

小伙伴是不是很好玩呀?赶紧尝试一下吧~

 

内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: