新手多线程使用详细教程以及讲解

多线程使用详细教程以及讲解

一、构建线程池

不少人会疑问为什么要构建线程池,而不是使用的时候去new线程呢?
答案主要有一下三点:
1.节约资源
复用已有的线程,减少创建线程、销毁线程浪费的资源。
2.提升速度
当有任务来的时候直接,不用等待新线程的创建,直接复用已用的线程
3.方便管理
可以控制线程的最大并发数,当线程超过规定数量时,统一回收等

通俗来讲:如果你每次调用方法都去new线程,当这个任务并发量足够大的时候,很有可能因为创建的线程数量过多而导致系统死机

/**
     * 创建固定长度线程池 允许自定义线程数<=20
     * 固定缓冲队列长度 500 防止无限制添加任务使内存溢出
     * @param threadLen
     * @return ExecutorService
     */
    public static ExecutorService buildExecutorService(int threadLen){
        ExecutorService executorService= new ThreadPoolExecutor(Math.min((threadLen + 1), 10),
                (Math.min((threadLen + 1), 10))*2,
                2,
                TimeUnit.SECONDS,
                new LimitedQueue<>(500),
                Executors.defaultThreadFactory(),
                new ThreadPoolExecutor.AbortPolicy());
        return executorService;
    }

二、线程池的使用
1.获取线程

    ExecutorService executorService= ThreadExportUtils.buildExecutorService(10);

2.使用多线程来执行业务代码

	for (String  data : list) {
      Runnable runnable = new Runnable() {
        @Override
        public void run() {
          //业务代码--start
          //业务代码--end
        }
      };
      executorService.execute(runnable);
    }

3.如果需要等所有线程执行完再去做其他操作,可以添加一些阻塞的代码(方式有很多种,这里我用一个计数器来实现)

	//往集合里面塞数据
	List<String> result = new ArrayList<>();
	CountDownLatch countDownLatch = new CountDownLatch(list.size());
    for (String  data : list) {
      Runnable runnable = new Runnable() {
        @Override
        public void run() {
          //业务代码--start 
	      String a = serviceImpl.getData(data);
	      result.add(a);
	      //业务代码--end
          countDownLatch.countDown();
        }
      };
      executorService.execute(runnable);
    }
  
	countDownLatch.await();//这里要处理一下异常
	//执行到这里的时候result中的结果就是所有线程执行完后的结果
	System.out.println("result = " + result);

4.使用工具类实现

	List<String> result = new ArrayList<>();
	List<CompletableFuture<Void>> futureList = new ArrayList<>();
    for (String  data : list) {
	    CompletableFuture<Void> courseTake = CompletableFuture.runAsync(() -> {
	       //业务代码--start 
	       String a = serviceImpl.getData(data);
	       result.add(a);
	       //业务代码--end
		}, executorService);
		futureList.add(courseTake);
    }

	//阻塞
	CompletableFuture<Void>[] completableFutures = futureList.toArray(new CompletableFuture[]{});
    CompletableFuture<Void> allOf = CompletableFuture.allOf(completableFutures);
    allOf.get();
    
	//执行到这里的时候result中的结果就是所有线程执行完后的结果
	System.out.println("result = " + result);
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 1
    评论
如果你是新手,这篇博客可能会对你有所帮助。博客的作者是B站黑马程序员的《python多线程编程》的视频的笔记摘录。博客中的代码是作者手动敲的,可以直接运行,如果有错误,作者欢迎评论指正。在博客中,有两个示例代码可以帮助你理解多线程的概念和使用方法。第一个示例是一个简单的多线程实现,其中一个线程用来唱歌,另一个线程用来跳舞。在示例代码中,使用了`threading.Thread`来创建两个线程,并分别指定了目标函数和参数。然后通过`start`方法启动线程。这样,两个线程就可以并发地执行唱歌和跳舞的任务。第二个示例代码展示了线程之间执行的顺序。在这个示例中,使用了`threading.current_thread`来获取当前线程线程对象,并打印出来。然后通过循环创建了5个子线程,并启动它们。由于多线程的执行是并发的,所以无法确定线程的执行顺序。希望这些示例代码对你理解和学习python多线程编程有所帮助。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *2* *3* [Python多线程编程(详细:适合小白入门)](https://blog.csdn.net/weixin_44917390/article/details/119610760)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 100%"] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

~~Whd

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

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

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

打赏作者

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

抵扣说明:

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

余额充值