java 实现线程的三种方式 Thread 、Runnable、 Callable Future

2024-06-14 16:38

本文主要是介绍java 实现线程的三种方式 Thread 、Runnable、 Callable Future,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

继承Thread类,重写run方法

例如:

/*** 实现线程方式一 继承Thread类* * @author wbw* */
public class MyThread1 extends Thread {@Overridepublic void run() {try {for (int i = 0; i < 10; i++) {System.out.println("Hello" + i);Thread.sleep(10000);}} catch (InterruptedException e) {e.printStackTrace();}}}
启动线程
package com.my.thread;public class Test {
public static void main(String[] args) {new MyThread1().start();
}
}
实现Runnable接口

package com.my.thread;
/*** 实现方式二: 实现抽象接口Runnable,在run方法中编写业务逻辑代码* @author wbw**/
public class MyThread2  implements Runnable{@Overridepublic void run() {try {for (int i = 0; i < 10; i++) {System.out.println("Hello" + i);Thread.sleep(10000);}} catch (InterruptedException e) {e.printStackTrace();}}}

在上面的两种实现方式,可以看出都能不能有返回值和不能抛出异常

在JDK1.5提供的新特性 Callable 和Fucture 可以允许线程有返回值

Callable的接口

public interface Callable<V> { V   call()   throws Exception; } 
Callable和Runnable的区别:

1. Callable定义的方法是call,而Runnable定义的方法是run。

2.  Callable的call方法可以有返回值,而Runnable的run方法不能有返回值。

3.  Callable的call方法可抛出异常,而Runnable的run方法不能抛出异常

4. Callable的启动可以通过创建ExecutorService对象调用sumbit()方法执行,也可以通过Thread的start()方法,而Runnable通过Thread的start()方法 

例子:
<strong>package com.my.thread;import java.util.concurrent.Callable;
/*** 实现方式三:实现Callable接口* @author wbw**/
public class MyThread3 implements Callable<String> {@Overridepublic String call() throws Exception {return "hello world";}}</strong>
启动:

<strong>package com.my.thread;import java.util.concurrent.ExecutorService;
import java.util.concurrent.Executors;public class Test {
public static void main(String[] args) {//Callable的启动方式MyThread3  task = new MyThread3();ExecutorService es =  Executors.newCachedThreadPool();es.submit(task);
}
}</strong>
Future用来保存Callable异步运算的结果

FutureTask封装Future的实体类

Future的接口如下:

<strong>public interface Future<V> {   boolean cancel(boolean mayInterruptIfRunning);   boolean isCancelled();   boolean isDone();   V get() throws InterruptedException, ExecutionException;   V get(long timeout, TimeUnit unit)   throws InterruptedException, ExecutionException, TimeoutException;   
}   </strong>
Callable 与Future
<strong>package com.my.thread;import java.util.concurrent.Callable;
import java.util.concurrent.ExecutionException;
import java.util.concurrent.ExecutorService;
import java.util.concurrent.Executors;
import java.util.concurrent.Future;
/*** 测试Callable* @author wbw**/
public class Test {
public static void main(String[] args) {try {//创建callable任务Callable<String>  task = new MyThread3();// 创建一个执行任务的服务ExecutorService es =  Executors.newCachedThreadPool();// 提交并执行任务,任务启动时返回了一个Future对象,Future<String> future =  es.submit(task);// 获得第一个任务的结果,如果调用get方法,当前线程会等待任务执行完毕后才往下执行,形成阻塞的状态System.out.println("Callable线程的返回值:"+future.get());//停止任务执行服务es.shutdownNow();} catch (InterruptedException | ExecutionException e) {e.printStackTrace();}
}
}</strong>
Callable 与FutureTask
<strong>	    try {Callable<String>  task2 = new MyThread3();//创建FutureTask对象FutureTask<String> ft = new FutureTask<String>(task2);Thread thread = new Thread(ft);thread.start();//启动Thread.sleep(100);if(!ft.isDone()){//判断当前线程的执行状态System.out.println(ft.get());}if(!ft.isCancelled()){//判断当前线程是否已被取消ft.cancel(true);System.out.println("Cancelled");}} catch (Exception e) {// TODO Auto-generated catch blocke.printStackTrace();}</strong>
三种实现线程的方式,根据实际情况选用


这篇关于java 实现线程的三种方式 Thread 、Runnable、 Callable Future的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1060947

相关文章

在Ubuntu上部署SpringBoot应用的操作步骤

《在Ubuntu上部署SpringBoot应用的操作步骤》随着云计算和容器化技术的普及,Linux服务器已成为部署Web应用程序的主流平台之一,Java作为一种跨平台的编程语言,具有广泛的应用场景,本... 目录一、部署准备二、安装 Java 环境1. 安装 JDK2. 验证 Java 安装三、安装 mys

Springboot的ThreadPoolTaskScheduler线程池轻松搞定15分钟不操作自动取消订单

《Springboot的ThreadPoolTaskScheduler线程池轻松搞定15分钟不操作自动取消订单》:本文主要介绍Springboot的ThreadPoolTaskScheduler线... 目录ThreadPoolTaskScheduler线程池实现15分钟不操作自动取消订单概要1,创建订单后

JAVA中整型数组、字符串数组、整型数和字符串 的创建与转换的方法

《JAVA中整型数组、字符串数组、整型数和字符串的创建与转换的方法》本文介绍了Java中字符串、字符数组和整型数组的创建方法,以及它们之间的转换方法,还详细讲解了字符串中的一些常用方法,如index... 目录一、字符串、字符数组和整型数组的创建1、字符串的创建方法1.1 通过引用字符数组来创建字符串1.2

Jsoncpp的安装与使用方式

《Jsoncpp的安装与使用方式》JsonCpp是一个用于解析和生成JSON数据的C++库,它支持解析JSON文件或字符串到C++对象,以及将C++对象序列化回JSON格式,安装JsonCpp可以通过... 目录安装jsoncppJsoncpp的使用Value类构造函数检测保存的数据类型提取数据对json数

Redis事务与数据持久化方式

《Redis事务与数据持久化方式》该文档主要介绍了Redis事务和持久化机制,事务通过将多个命令打包执行,而持久化则通过快照(RDB)和追加式文件(AOF)两种方式将内存数据保存到磁盘,以防止数据丢失... 目录一、Redis 事务1.1 事务本质1.2 数据库事务与redis事务1.2.1 数据库事务1.

python使用watchdog实现文件资源监控

《python使用watchdog实现文件资源监控》watchdog支持跨平台文件资源监控,可以检测指定文件夹下文件及文件夹变动,下面我们来看看Python如何使用watchdog实现文件资源监控吧... python文件监控库watchdogs简介随着Python在各种应用领域中的广泛使用,其生态环境也

el-select下拉选择缓存的实现

《el-select下拉选择缓存的实现》本文主要介绍了在使用el-select实现下拉选择缓存时遇到的问题及解决方案,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的... 目录项目场景:问题描述解决方案:项目场景:从左侧列表中选取字段填入右侧下拉多选框,用户可以对右侧

Linux磁盘分区、格式化和挂载方式

《Linux磁盘分区、格式化和挂载方式》本文详细介绍了Linux系统中磁盘分区、格式化和挂载的基本操作步骤和命令,包括MBR和GPT分区表的区别、fdisk和gdisk命令的使用、常见的文件系统格式以... 目录一、磁盘分区表分类二、fdisk命令创建分区1、交互式的命令2、分区主分区3、创建扩展分区,然后

SpringCloud集成AlloyDB的示例代码

《SpringCloud集成AlloyDB的示例代码》AlloyDB是GoogleCloud提供的一种高度可扩展、强性能的关系型数据库服务,它兼容PostgreSQL,并提供了更快的查询性能... 目录1.AlloyDBjavascript是什么?AlloyDB 的工作原理2.搭建测试环境3.代码工程1.

Linux中chmod权限设置方式

《Linux中chmod权限设置方式》本文介绍了Linux系统中文件和目录权限的设置方法,包括chmod、chown和chgrp命令的使用,以及权限模式和符号模式的详细说明,通过这些命令,用户可以灵活... 目录设置基本权限命令:chmod1、权限介绍2、chmod命令常见用法和示例3、文件权限详解4、ch