Java多线程-线程池的使用与线程总结(狂神说含代码)

Posted 轻狂书生han

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Java多线程-线程池的使用与线程总结(狂神说含代码)相关的知识,希望对你有一定的参考价值。

使用线程池

  • 背景:经常创建和销毁、使用量特别大的资源,比如并发情况下的线程,对性能影响很大

  • 思路:提前创建好多个线程,放入线程池中,使用时直接获取,使用完放回池中。可以避免频繁创建销毁,实现重复利用。类似生活中的公共交通工具。

  • 好处:

    • 提高响应速度(减少了创建新线程的时间)
    • 降低资源消耗(重复利用线程池中线程,不需要每次都创建)
    • 便于线程管理(...)
      • cornPoolSize:核心池的大小
      • maximumPoolSize:最大线程数
      • keepAliveTime:线程没有任务最多保持多长时间后就会终止
  • JDK5.0起提供了线程池相关API:ExecutorService和Executors

  • ExecutorService:真正的线程池接口。常见子类ThreadPoolExecutor

    • void execute(Runnable command):执行任务、命令,没有返回值,一般用来执行Runnable
    • Futuresubmit(Callcabletask):执行任务,有返回值,一般又来执行Callable
    • void shutdown():关闭连接池
  • Executors:工具类,线程池的工厂类,用于创建并返回不同类型的线程池
package com.thread;

import java.util.concurrent.ExecutorService;
import java.util.concurrent.Executors;

//测试线程池
public class TestPool 
    public static void main(String[] args) 
        //1.创建服务,创建线程池
        //newFixedThreadPool 参数为线程池的大小
        ExecutorService service = Executors.newFixedThreadPool(10);

        service.execute(new MyThread());
        service.execute(new MyThread());
        service.execute(new MyThread());
        service.execute(new MyThread());

        //关闭连接
        service.shutdown();

    




class MyThread implements Runnable
    @Override
    public void run() 

        System.out.println(Thread.currentThread().getName());

    

package com.thread.gaoji;

import java.util.concurrent.Callable;
import java.util.concurrent.ExecutionException;
import java.util.concurrent.FutureTask;

//回顾总结线程的创建
public class ThreadNew 
    public static void main(String[] args) 
        new MyThread1().start();

        new Thread(new Mythread2()).start();

        FutureTask<Integer> futureTask = new FutureTask<Integer>(new MyThread3());
        new Thread(futureTask).start();

        try 
            Integer integer = futureTask.get();
            System.out.println(integer);
         catch (InterruptedException e) 
            e.printStackTrace();
         catch (ExecutionException e) 
            e.printStackTrace();
        
    


//1.继承Thread类
class MyThread1 extends Thread
    @Override
    public void run() 
        System.out.println("MyThread");
    


//2.实现runnable接口
class Mythread2 implements Runnable
    @Override
    public void run() 
        System.out.println("MyThread2");
    

//实现callable接口
class MyThread3 implements Callable<Integer>
    @Override
    public Integer call() throws Exception 
        System.out.println("MyThread3");

        return 100;
    

以上是关于Java多线程-线程池的使用与线程总结(狂神说含代码)的主要内容,如果未能解决你的问题,请参考以下文章

《狂神说——多线程》

B站狂神说Java笔记-多线程

java多线程远程协作(狂神说)附上课代码

狂神说 多线程

Java多线程入门

多线程详解