多线程推送消息demo

package com.example.demo.duoXianCheng;

import java.util.ArrayList;
import java.util.List;
import java.util.concurrent.Callable;
import java.util.concurrent.ExecutorService;
import java.util.concurrent.Executors;
import java.util.concurrent.Future;
import java.util.concurrent.atomic.AtomicInteger;

public class PublishMsgTest {
    //创建固定大小为100 的线程池
    private static ExecutorService service = Executors.newFixedThreadPool(100);
    
    //发送消息的业务逻辑方法
    public int sendMsg(List<Integer> receivers, String content){
        long begin = System.nanoTime();
        AtomicInteger ai = new AtomicInteger(0);
        List<Future<Integer>> list = new ArrayList<>();
        //循环发送消息
        for(int i=0;i<receivers.size();i++){
            Integer receiver = receivers.get(i);
            //使用Future,Callable实现发送消息后返回发送结果
            Future<Integer> future = service.submit(new Callable<Integer>() {
                @Override
                public Integer call() throws Exception {
                    //调用相对比较耗时的发送消息接口
                    Thread.sleep(200);
                    //发送消息
                    int resultStatus = sendMsg(receiver,content);
                    System.out.println("接收者【"+receiver+"】,发送结果【"+resultStatus+"】");
                    return resultStatus;
                }
            });
            list.add(future);
        }
        System.out.println("-----------------------"+(System.nanoTime()-begin)/1000_000d+"-----------------------");
        //循环接收发送结果,相当于一个使线程同步的过程,这个过程是比较耗时的
        for(int i=0;i<list.size();i++){
            try {
                int resultStatus = list.get(i).get();
                if(resultStatus == 0){//发送成功
                    ai.incrementAndGet();
                }
            } catch (Exception e) {
                e.printStackTrace();
            } 
        }
        System.out.println("发送消息结束,耗时:"+(System.nanoTime()-begin)/1000_000d);
        return ai.get();
    }
    
    public static void main(String[] args){
        PublishMsgTest pmt = new PublishMsgTest();
        //待接收人
        List<Integer> receivers = new ArrayList<Integer>();
        for(int i=0;i<1000;i++){
            receivers.add(i);
        }
        String content = "群发消息_测试代码";
        int successCount = pmt.sendMsg(receivers, content);
        System.out.println("共有【"+receivers.size()+"】接收者,发送成功【"+successCount+"】");
    }

    //完成发送消息
    private int sendMsg(Integer receiver, String content) {
        if(receiver%2 == 0){//模拟被2整除,即为发送成功
            return 0;
        }
        return 1;
    }
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值