美文网首页
java多线程实现的方式及线程池使用

java多线程实现的方式及线程池使用

作者: 张不二01 | 来源:发表于2017-08-27 14:53 被阅读166次

创建新执行线程有两种方法。
1,将类声明为 Thread 的子类。该子类应重写 Thread 类的 run 方法。通过创建该子类并调用start方法来实现
2,声明实现 Runnable 接口的类。该类然后实现 run 方法。然后可以分配该类的实例,在创建 Thread 时作为一个参数来传递并启动,其中,接口的匿名内部类比较常用
3,线程池原理也就是一个Thread的集合

1,继承方式创建新线程(lang包下Thread)

*1.1,最基本的方式实现继承方式创建新线程

//继承父类
public class Thread01 extends Thread {
    @Override
    public void run() {
        //做你需要在新线程实现的代码
        System.out.println(Thread.currentThread());
        super.run();
    }
}

//使用方式:第一种方式开辟一条新的线程
Thread newThread = new Thread01();
 newThread.start();
  • 1.2,使用匿名内部类实现继承方式创建新线程
Thread newThread02 = new Thread(){
    @Override
    public void run() {
        //做你需要在新线程实现的代码
        System.out.println("iooo");
        System.out.println(Thread.currentThread());
        super.run();
    }
};
newThread02.start();
2,实现接口方式创建新线程(lang包下Runnable)
  • 2.1,最基本的方式实现接口方式创建新线程
//实现借口
public class Runnable01 implements Runnable {
    @Override
    public void run() {
        //你需要在新线程实现的代码
        System.out.println(Thread.currentThread());
    }
}

//使用方式:第二种方式开辟一条新的线程
Runnable01 runnable01 = new Runnable01();
new Thread(runnable01).start();
  • 2.1,使用匿名内部类实现接口方式创建新的线程
    这种方式我不需要手动的创建一个类实现借口,可以直接使用匿名内部类进行创建,比较方便
//通过匿名内部类实现Runnable接口,并使用引用指向该接口实现
Runnable runnable02 = new Runnable(){
            @Override
            public void run() {
                //这里写你要在该新线程中执行的代码
                System.out.println(Thread.currentThread());
            }
        };

//使用方式:使用匿名内部类实现创建新的线程
new Thread(runnable02).start();

3,线程池使用(utils包下的子包concurrent包下的Executors工具类)

  • 3.1,通过Runnable来传递任务到线程上,这种方式是没有返回值的,也不会影响主线程
//线程池的使用
//1,使用工厂类的静态方法创建一个线程对象,指定线程个数
ExecutorService executorService = Executors.newFixedThreadPool(2);
//2,通过传递Runnable来传递任务到线程上
executorService.submit(new Runnable() {
    @Override
    public void run() {
        System.out.println("这是线程池中的一个任务");
        System.out.println(Thread.currentThread());
    }
});
executorService.submit(new Runnable() {
    @Override
    public void run() {
        System.out.println("这是线程池中的第二任务");
        System.out.println(Thread.currentThread());
    }
});
executorService.submit(new Runnable() {
    @Override
    public void run() {
        System.out.println("这是线程池中的第三任务");
        System.out.println(Thread.currentThread());
    }
});
  • 3.2,通过Callable传递任务到线程上, 有返回值,注意:这里是会阻塞主线程直到拿到返回结果。用Callable和直接在主线程执行的不同之处就是:这种创建新线程的方式可以同时执行多个任务,然后拿到结果,返回给主线程,然后主线程继续往下执行
ExecutorService executorService01 = Executors.newFixedThreadPool(3);
Future<String> future = executorService01.submit(new Callable<String>(){
    @Override
    public String call() throws Exception {
        System.out.println(Thread.currentThread());
        for (int i = 0; i < 200; i++) {
            System.out.println(i);
        }
        return "zhangdanfeng";
    }
});
String s = future.get();
System.out.println(s);
//注意:在拿到新线程任务的返回值之前,主线程是被阻塞的,所以下面的打印必定是在最后的
System.out.println("==============================");

相关文章

网友评论

      本文标题:java多线程实现的方式及线程池使用

      本文链接:https://www.haomeiwen.com/subject/bvvbdxtx.html