多线程在Java项目中的使用案例(笔记)

多线程在Java项目中的使用案例(笔记)

  1. 实现runnable接口
@Override
    public Boolean addMeetingExpertIds(MeetAddExpertDto meetAddExpertDto, Long userId) {
        // 会议关联到专家
        // 如果需要发给专家
        new Thread(new Runnable() {
            @Override
            public void run() {
                try {
                    if (meetAddExpertDto.getExpertIdList().size() > 0) {
                        // 准备通知数据
                        List<AddMeeTempDto> addMeeTempDtoList = new ArrayList<>();
                        for (Long expertId : meetAddExpertDto.getExpertIdList()) {
                            AddMeeTempDto addMeeTempDto = new AddMeeTempDto()
                                    .setExpertId(expertId)
                                    .setTemplateDetail(meetAddExpertDto.getTemplate() + expertId);
                            addMeeTempDtoList.add(addMeeTempDto);
                        }
                        expertMeetingService.addExpertMeetingBatch(meetAddExpertDto.getMeetingId(), addMeeTempDtoList, userId);
                        Thread.sleep(300);
                    }
                } catch (Exception e) {
                    e.printStackTrace();
                } finally {
                    log.info("线程结束");
                }
            }
        }).start();
        return true;
    }

Lambda写法

@Override
    public void test(Integer meetId) {

        new Thread(() -> {
            try {
                for (int i = 0; i < 10; i++) {
                    log.info("线程" + meetId + "正在输出" + i);//逻辑代码
                    if (i == 5) {
                        Thread.sleep(200);
                        log.info("线程" + meetId + "睡眠");
                    }
                }
            } catch (InterruptedException e) {
                e.printStackTrace();
            } finally {
                log.info("线程结束");
            }
        }).start();
    }
  1. 创建线程池
@Override
    public void test(Integer meetId) {
        //创建一个具有10个线程的线程池
        ExecutorService threadPool = Executors.newFixedThreadPool(10);
        long threadpoolUseTime = System.currentTimeMillis();
        threadPool.execute(new Runnable() {
            @Override
            public void run() {
                try {
                    for (int i = 0; i < 10; i++) {
                        log.info("线程" + meetId + "正在输出" + i);
                        if (i == 5) {
                            Thread.sleep(200);
                            log.info("线程" + meetId + "睡眠");
                        }
                    }
                } catch (InterruptedException e) {
                    e.printStackTrace();
                }
            }
        });
        long threadpoolUseTime1 = System.currentTimeMillis();
        System.out.println("多线程用时"+(threadpoolUseTime1-threadpoolUseTime));
        //销毁线程池
        threadPool.shutdown();
    }

Lambda写法

@Override
    public void test(Integer meetId) {
        //创建一个具有10个线程的线程池
        ExecutorService threadPool = Executors.newFixedThreadPool(10);
        long threadpoolUseTime = System.currentTimeMillis();
        threadPool.execute(new Runnable() {
            @Override
            public void run() {
                try {
                    for (int i = 0; i < 10; i++) {
                        log.info("线程" + meetId + "正在输出" + i);
                        if (i == 5) {
                            Thread.sleep(200);
                            log.info("线程" + meetId + "睡眠");
                        }
                    }
                } catch (InterruptedException e) {
                    e.printStackTrace();
                }
            }
        });
        long threadpoolUseTime1 = System.currentTimeMillis();
        System.out.println("多线程用时"+(threadpoolUseTime1-threadpoolUseTime));
        //销毁线程池
        threadPool.shutdown();
    }
  • 2
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值