功能需求:
执行某一些查询完成后,通过邮箱服务器发送邮件通知,并将查询结果返回。
因为是遍历查询,每次查询都需要发邮件,最后才能返回结果,发送邮件功能占用时间较长,导致返回结果速度很慢。于是采用异步处理方法,进行性能优化。
package com.test;
import java.util.concurrent.Executors;
import java.util.concurrent.ThreadPoolExecutor;
public class MyExecutor {
//创建线程池
ThreadPoolExecutor executor = (ThreadPoolExecutor) Executors.newCachedThreadPool();
public void SenEmail(String msg){
executor.submit(()->{
System.out.println("正在发送邮件-----");
try {
//调用发送邮件功能,线程等待模拟时间
Thread.sleep(3000);
} catch (InterruptedException e) {
e.printStackTrace();
}
System.out.println("邮件发送完成"+msg);
});
}
}
调用方法完成查询:
package com.test;
public class Test {
public static void main(String[] args) throws InterruptedException {
StringBuilder info = new StringBuilder();
//执行遍历
for (int i = 0; i < 3; i++) {
String str =selectInfo(i)+i+"-";
info.append(str);
}
System.out.println("获取返回的信息:------"+info);
}
//查询相关信息
public static String selectInfo(int i) {
System.out.println("开始查询相关信息"+i);
String str = "返回查询信息"+i;
//发送邮件
MyExecutor executor = new MyExecutor();
executor.SenEmail("sendEmail"+i);
return str;
}
}
运行结果:
开始查询相关信息0
开始查询相关信息1
开始查询相关信息2
获取返回的信息:------返回查询信息00-返回查询信息11-返回查询信息22-
正在发送邮件-----
正在发送邮件-----
正在发送邮件-----
邮件发送完成sendEmail2
邮件发送完成sendEmail0
邮件发送完成sendEmail1
根据输出信息可以看到已经达到效果,方法返回结果以后,相关邮件才完成发送,这个就提高了查询的效率,在性能上有了进一步的提升。