简单了解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()方法。
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。
相关文章
spring boot org.junit.jupiter.api不存在的解决
这篇文章主要介绍了spring boot org.junit.jupiter.api不存在的解决方案,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教2021-09-09
SpringBoot使用slf4j日志并输出到文件中的操作方法
这篇文章主要介绍了SpringBoot使用slf4j日志并输出到文件中,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下2023-08-08
jdk中keytool的使用以及如何提取jks文件中的公钥和私钥
JKS文件由公钥和密钥构成利用Java Keytool工具生成的文件,它是由公钥和密钥构成的,下面这篇文章主要给大家介绍了关于jdk中keytool的使用以及如何提取jks文件中公钥和私钥的相关资料,需要的朋友可以参考下2024-03-03


最新评论