简单了解Java多线程实现的四种方式

第一种方式为继承Thread类然后重写run方法再调用start方法,因为java为单继承多实现,所以不建议使用这种方式,代码如下:

public class Demo extends Thread{

  public static void main(String[] args) {
    new Demo().start();
  }

  @Override
  public void run() {
    System.out.println("继承Thread类实现多线程");
  }
}

第二种为实现Runnable接口方式,该方式用的较多,代码如下:

public class Demo2 implements Runnable{

  public static void main(String[] args) {
    new Thread(new Demo2()).start();
  }

  @Override
  public void run() {
    System.out.println("实现Runnable接口的多线程");
  }
}

第三种为实现Callable接口方式,该方式run方法具有返回值,代码如下:

public class Demo3 implements Callable {

  public static void main(String[] args) throws ExecutionException, InterruptedException {
    FutureTask task=new FutureTask(new Demo3());
    new Thread(task).start();
    System.out.println(task.get());
  }

  @Override
  public String call() throws Exception {
    return "实现Callable接口的多线程";
  }
}

第四种是采用线程池的方式,代码如下:

public class Demo4 {

  public static void main(String[] args) {
    ExecutorService executorService= Executors.newCachedThreadPool();
    executorService.execute(new Runnable() {
      @Override
      public void run() {
        System.out.println("线程池实现多线程");
      }
    });
    
    executorService.shutdown();
  }
}

从上面我们可以看出线程的调用都是采用start()方法,那么调用直接调用run()方法其实也是可以输出结果的,但是有着本质的区别,因为调用start()方法会使得当前线程的数量增加,而单纯得调用run()方法是不会的,在start()方法的内部其实包含了调用run()方法。

最新2020整理收集的一些高频面试题(都整理成文档),有很多干货,包含mysql,netty,spring,线程,spring cloud、jvm、源码、算法等详细讲解,也有详细的学习规划图,面试题整理等,需要获取这些内容的朋友请加Q君样:11604713672

猜你喜欢

转载自blog.csdn.net/weixin_51495453/article/details/113866201