JAVA 多线程并发1-多线程的创建方式

Lewis
2022-02-15 / 0 评论 / 150 阅读 / 正在检测是否收录...

1.并发知识库

kznhbuc3.png

2.JAVA线程实现/创建的方式

2.1 通过继承Thread实现多线程

Thread类本质是实现了runnable接口的一个实例。启动线程的唯一方法就是通过 Thread 类的 start()实例方法。start()方法是一个 native方法,它将启动一个新线程,并执行 run()方法。

kznhyu06.png

/**
 * 时间 2022/2/15 10:04
 * 作者 lvwei
 * 邮箱 lvwei@bdysoft.com
 * 版本 1.0
 */
class testThread {
        public void main(String[] args) {
            MyThread myThread = new MyThread("A");
            myThread.start();
        }
    }
    class MyThread extends Thread {
        private String name;
        public MyThread(String name) {
            this.name=name;
        }
        @Override
        public void run() {
            System.out.println("通过继承Thread实现多线程....");
        }
    }

2.2 通过实现runable接口实现多线程

通过2.1我们了解到Thread类是实现了Runable使自己具备子线程能力,那么同理我们自己的类也可以实现Runable接口来使自己实现子线程。
 public void test() {
        System.out.println("主线程:" + Thread.currentThread().getId());
        MyThread2 myThread2 = new MyThread2();
        new Thread(myThread2).start();
    }

    class MyThread2 implements Runnable {
        @Override
        public void run() {
            System.out.println("子线程:" + Thread.currentThread().getId() + "===>通过实现Runable实现多线程....");
        }
    }

2.3 ExecutorService、Callable、Future 有返回值线程

有返回值的任务必须实现 Callable 接口,类似的,无返回值的任务必须 Runnable 接口。执行Callable 任务后,可以获取一个 Future 的对象,在该对象上调用 get 就可以获取到 Callable 任务返回的 Object 了,再结合线程池接口 ExecutorService 就可以实现传说中有返回结果的多线程了。

//创建一个线程池
ExecutorService pool = Executors.newFixedThreadPool(taskSize);
// 创建多个有返回值的任务
List<Future> list = new ArrayList<Future>(); 
for (int i = 0; i < taskSize; i++) { 
Callable c = new MyCallable(i + " "); 
// 执行任务并获取 Future 对象
Future f = pool.submit(c); 
list.add(f); 
} 
// 关闭线程池
pool.shutdown(); 
// 获取所有并发任务的运行结果
for (Future f : list) { 
// 从 Future 对象上获取任务的返回值,并输出到控制台
System.out.println("res:" + f.get().toString()); 
}

2.4 基于线程池的方式

线程和数据库连接这些资源都是非常宝贵的资源。那么每次需要的时候创建,不需要的时候销
毁,是非常浪费资源的。那么我们就可以使用缓存的策略,也就是使用线程池。
 // 创建一个线程池
        ExecutorService pool = Executors.newFixedThreadPool(5);
        // 创建多个有返回值的任务
        ArrayList<Future> futureArrayList = new ArrayList<>();
        for (int i = 0; i < 5; i++) {
            Callable callable = new Callable() {
                @Override
                public Object call() throws Exception {
                    return "当前执行的线程为:" + Thread.currentThread().getId();
                }
            };
            // 执行任务并获取 Future 对象
            Future future = pool.submit(callable);
            futureArrayList.add(future);
        }
        // 关闭线程池
        pool.shutdown();
        // 获取所有并发的运行结果
        for (Future future : futureArrayList) {
            // 从 Future 对象上获取任务的返回值,并输出到控制
            System.out.println(future.get().toString());
        }
0

评论 (0)

取消