ThreadPoolExecutor 简单应用

适用场景:读取数据库数据,刷数据等批量操作

直接上代码

package test;
import com.alibaba.fastjson.JSONObject;
import io.tava.function.Consumer1;
import org.springframework.stereotype.Component;

@Component
public class Producers  implements Consumer1<JSONObject>{
    private ThreadPoolDemo threadPoolDemo;

    public Producers(ThreadPoolDemo threadPoolDemo) {
        this.threadPoolDemo = threadPoolDemo;
    }

    @Override
    public void accept(JSONObject msg) {
        //生产
        threadPoolDemo.execute(new Consumers(msg));
    }
}

package test;
import com.alibaba.fastjson.JSONObject;

public class Consumers implements Runnable {

    private final JSONObject msg;

    Consumers(JSONObject msg) {
        this.msg = msg;
    }

    @Override
    public void run() {
        //消费执行
        System.out.println("消费者消费了:"+msg.toJSONString());
    }
}

package test;

import io.tava.util.BlockRejectedExecutionHandler;
import io.tava.util.NamedThreadFactory;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service;

import java.util.concurrent.ArrayBlockingQueue;
import java.util.concurrent.ThreadPoolExecutor;
import java.util.concurrent.TimeUnit;

@Service
public class ThreadPoolDemo {

    public final ThreadPoolExecutor threadPoolExecutor;

    @Autowired
    public ThreadPoolDemo() {
        int coreThreadSize = 32;
        int maxThreadSize = 32;
        int workQueueCapacity = 102400;
        this.threadPoolExecutor = new ThreadPoolExecutor(
                coreThreadSize,
                maxThreadSize,
                1,
                TimeUnit.MINUTES,
                new ArrayBlockingQueue<>(workQueueCapacity),
                new NamedThreadFactory("full-indexer"),
                BlockRejectedExecutionHandler.getInstance());
    }

    public void execute(Runnable command) {
        threadPoolExecutor.execute(command);
    }

}

package test;

import com.alibaba.fastjson.JSONObject;

public class main {


    public static void main(String[] args) {
        Producers producers = new Producers(new ThreadPoolDemo());
        for (int i = 0; i < 10000; i++) {
            JSONObject msg = new JSONObject();
            msg.put("执行id",i);
            producers.accept(msg);
        }
    }
}


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值