首页 > 其他分享 >实现多线程的方式有哪几种?

实现多线程的方式有哪几种?

时间:2024-01-27 15:23:21浏览次数:34  
标签:Runnable run 方式 Thread 线程 哪几种 多线程 方法 public

Java虚拟机时是运行所有Java程序的抽象计算机,允许应用并发的运行多个线程。在Java语言中,多线程的实现,一般有以下3中方法:

1.实现Runnable接口,并实现该接口的run()方法;
主要步骤:
1.自定义类并实现Runnable接口,实现run()方法;
2.创建Thread类,用实现Runnable接口的对象作为参数实例化该Thread对象;
3.调用Thread类的start()方法;

class MyThread implements Runnable{
//创建线程
public void run(){
System.out.println("Thread body");
}
}

public class Test{
public static void main(String[]args){
MyThread thread=new MyThread();
Thread t=new Thread(thread);
t.start;//开启线程
}
}

2.继承Thread类,重写run方法
Thread类本质上也是实现了Runnable接口的一个实例,它代表一个线程的实例,并且,启动线程的唯一方法就是通过Thread类的start()方法。start()方法是一个native(本地)方法,它将启动一个新线程,并执行run()方法。这种方式通过自定义类直接extends Thread,并重写run()方法,就可以启动新线程并执行自己定义的run()方法。需要注意的是,当star()方法调用后并不是立即执行多线程代码,而是使得该线程变为可运行态(Runnable),什么时候运行多线程代码是由操作系统决定的。

class MyThread extends Thread{
//创建线程类
public void run(){
System.out.println("Thread body");
}
}

public class Test{
public static void main(String[]args){
MyThread thread=new MyThread();
thread.start();//开启线程
}
}

3.实现Callable接口,重写call()方法;
Callable对象实际上是属于Excutor框架中的功能类,Callable接口与Runnable接口类似,但是提供了比Runnable接口更强大的功能,主要表现为以下三点:

1.Callable可以在任务结束后提供一个返回值,Runnable无法提供这个功能;
2.Callable中的call()方法可以抛出异常,而Runnable的run方法不能抛出异常;
3.运行Callable可以拿到一个Future对象,Future对象表示异步计算的结果。它提供了检查计算是否完成的方法。由于线程属于异步计算模型,所以无法从其他线程中得到方法的返回值,在这种情况下,就可以使用Future来监视目标线程调用call()方法的情况,当调用Future的get()方法以获取结果时,当前线程就会阻塞,直到call()方法结束返回结果。

import java.util.concurrent.*
public class CallableAndFuture{
public static class CallableTest implements Callable{
public String call()throws Exception{
return "Hello World!"
}
}

public static void main(String []args){
ExcutorService threadPool=Executor.newSingleThreadExecutor();

Future<String>future=threadPool.submit(new CallableTest());

try{
  System.out.println("waiting thread to finish");
  System.out.println(future.get());
}
catch(Exception e){
  e.printStackTrace();
}

}
}

标签:Runnable,run,方式,Thread,线程,哪几种,多线程,方法,public
From: https://www.cnblogs.com/yige888/p/17991479

相关文章

  • python 多线程运行 串行或并行
    我们知道在python中运行多线程程序很简单,只需要几步,创建线程,start线程即可,下面简单说下多线程的串行或者并行的使用示例:#-*-coding:utf-8-*-#@Time:2024-01-2714:03importthreadingimporttimedefrun(name:str)->None:time.sleep(3)print("Thre......
  • 多线程简单介绍
    线程:是操作系统能够进行运算调度的最小单位。它被包含在进程中,是进程中实际运作单位进程:进程是程序的基本执行实体,一个程序就是一个进程简单理解线程:应用软件中相互独立,可以同时运行的功能有了多线程,就可以让程序同时做多件事线程的生命周期完整的线程状态New(新建状态)->......
  • 多线程sleep、yield、wait、join方法的使用和区别
    使用和介绍sleep方法sleep方法的官方注释(翻译后):/***根据系统计时器和调度程序的精度和准确性,使当前执行的线程休眠(暂时停止执行)指定的毫秒数。线程不会失去任何监视器的所有权(不释放锁)。**@parammillis以毫秒为单位的睡眠时间长度*@throws......
  • SpringMVC之域对象共享数据的多种方式
    本次场景演示使用Thymeleaf服务器渲染技术。使用Servlet向域中共享数据@GetMapping("/testServletScope")publicStringtestServlet(HttpServletRequestrequest){request.setAttribute("testServletScope","hello,servlet");return"success&qu......
  • xxl-job之API的方式接入
    目录1xxl-job1.1简介1.2分析1.3学***l-job源码1.4改造项目1.4.1接口调用1.4.1.1对接登录接口1.4.1.2对接执行器接口1.4.1.3对接任务接口1.4.2创建新注解1.4.3自动注册核心1.4.4自动装配1xxl-job1.1简介xxl-job是一款非常优秀的任务调度中间件,轻量级、使用简单、......
  • golang 遍历目录的两种方式、删除目录的两种方式
    funcmain(){ directory:="/Users/mike/Downloads" //不会递归只会读取当前的单层目录 directories,err:=os.ReadDir(directory) iferr!=nil{ fmt.Println(err) } for_,d:=rangedirectories{ fmt.Println(d.Name(),d.IsDir()) } //会递归遍历所......
  • WPF,ListView鼠标上下滚动方式修改
    问题:ListView在鼠标上下滚动的时候,是按照一个一个Item的高度来滚动的,有办法取消掉这样子的滚动方式吗解决方式:可以通过将ListView的ScrollViewer.CanContentScroll属性设置为False来取消掉逐个项滚动的方式。这将会启用平滑滚动,而不是基于项的高度进行滚动示例代码如下:<......
  • rpa使用自带数据抓取方式抓取页面元素
    大家好,我是一方。今天我们一起看一下如何使用rpa自带的功能来抓取自己想要的页面元素,这里我们以抖音为例来抓取某个领域的作者列表。想要获取页面元素,大概的流程为:确定页面元素、分析页面元素、使用自带的工具便捷抓取元素。我们正式开始,首先新建一个抖音作者列表的项目,并快速......
  • centos openjdk 11 安装软件包获取方式
    centosopenjdk11安装软件包获取方式 1、openjdk 的官网在官网上可以看到openjdk11 本身最新版本为:(http://jdk.java.net/archive/) 可以看到最新版本为11GA(11+28)点击 Source 按钮(https://hg.openjdk.java.net/jdk/jdk11),可以看到jdk11 一直依赖的代码更新记录......
  • Java web 应用程序的部署方式有哪些
    当我们开发完一个JavaWeb应用程序后,接下来需要将其部署到服务器上,以便用户可以通过浏览器访问。本文将介绍几种常见的JavaWeb应用程序的部署方式。一、独立容器独立容器是最常见的部署方式之一,它是指将JavaWeb应用程序打包成一个独立的WAR文件,然后将该WAR文件部署到独立的Servle......