Spring @EnableAsync &@Async 实现方法异步调用 方式一

112 篇文章 3 订阅
105 篇文章 20 订阅

1、异步测试类

package com.async2;

import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.ComponentScan;
import org.springframework.context.annotation.Primary;
import org.springframework.scheduling.annotation.EnableAsync;
import org.springframework.scheduling.concurrent.ThreadPoolTaskExecutor;

import java.util.concurrent.Executor;

@EnableAsync
@ComponentScan
public class BeanConfig {

    public static final String ADD_EXECUTOR = "addExecutor";
    public static final String REDUCE_EXECUTOR = "reduceExecutor";

    @Primary
    @Bean(ADD_EXECUTOR)
    public Executor addExecutor() {
        ThreadPoolTaskExecutor executor = new ThreadPoolTaskExecutor();
        executor.setCorePoolSize(10);
        executor.setMaxPoolSize(100);
        //线程名称前缀
        executor.setThreadNamePrefix("add-thread-");
        return executor;
    }

    @Bean(REDUCE_EXECUTOR)
    public Executor reduceExecutor() {
        ThreadPoolTaskExecutor executor = new ThreadPoolTaskExecutor();
        executor.setCorePoolSize(10);
        executor.setMaxPoolSize(100);
        //线程名称前缀
        executor.setThreadNamePrefix("reduce-thread-");
        return executor;
    }
}

2、业务类

package com.async2;

import org.springframework.scheduling.annotation.Async;
import org.springframework.scheduling.concurrent.ThreadPoolTaskExecutor;
import org.springframework.stereotype.Component;

import javax.annotation.Resource;
import java.util.concurrent.Callable;
import java.util.concurrent.Future;

@Component
public class AccountService {


    @Resource(name = BeanConfig.ADD_EXECUTOR)
    private ThreadPoolTaskExecutor addExecutor;


    @Async(BeanConfig.ADD_EXECUTOR)
    public void add() {
        System.out.println(Thread.currentThread() + "账户充值");
    }

    @Async
    public void add2() {
        addExecutor.execute(new Runnable() {
            @Override
            public void run() {
                //业务方法或其他业务方法的调用
                System.out.println(Thread.currentThread() + "账户充值2");
            }
        });

    }

    @Async
    public Future<String> add3() {
        return addExecutor.submit(new Callable<String>() {
            @Override
            public String call() throws Exception {
                System.out.println(Thread.currentThread() + "账户充值2");
                return "success ";
            }
        });
    }

    @Async(BeanConfig.REDUCE_EXECUTOR)
    public void reduce() {
        System.out.println(Thread.currentThread() + "账户提现");
    }

    //不指定线程池,默认primary线程池,无primary则默认使用SimpleAsyncTaskExecutor
    @Async
    public void transfer() {
        System.out.println(Thread.currentThread() + "账户转账");
    }


}

3、异步线程池定义

package com.async2;

import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.ComponentScan;
import org.springframework.context.annotation.Primary;
import org.springframework.scheduling.annotation.EnableAsync;
import org.springframework.scheduling.concurrent.ThreadPoolTaskExecutor;

import java.util.concurrent.Executor;

@EnableAsync
@ComponentScan
public class BeanConfig {

    public static final String ADD_EXECUTOR = "addExecutor";
    public static final String REDUCE_EXECUTOR = "reduceExecutor";

    @Primary
    @Bean(ADD_EXECUTOR)
    public Executor addExecutor() {
        ThreadPoolTaskExecutor executor = new ThreadPoolTaskExecutor();
        executor.setCorePoolSize(10);
        executor.setMaxPoolSize(100);
        //线程名称前缀
        executor.setThreadNamePrefix("add-thread-");
        return executor;
    }

    @Bean(REDUCE_EXECUTOR)
    public Executor reduceExecutor() {
        ThreadPoolTaskExecutor executor = new ThreadPoolTaskExecutor();
        executor.setCorePoolSize(10);
        executor.setMaxPoolSize(100);
        //线程名称前缀
        executor.setThreadNamePrefix("reduce-thread-");
        return executor;
    }
}

4、打印输出

Thread[add-thread-1,5,main]账户充值
Thread[reduce-thread-1,5,main]账户提现
Thread[add-thread-4,5,main]账户转账
Thread[add-thread-6,5,main]账户充值2
Thread[add-thread-5,5,main]账户充值2
add3方法充值成功返回消息:success 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

春风化作秋雨

你的鼓励将是我创作的最大动力!

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值