如果有人问题你,多线程可以有返回值吗?你怎么回答?
看下面例子,我定义了一个类实现了Callable 接口
public class MyCallable implements Callable<Object> { @Override public Object call() throws Exception { int i=10; Thread.sleep(10000); return i; } }
Callable如果要想得到返回值需要通过一个叫FutureTask的类帮助。简单的做法是这样的
public void test1() { try { FutureTask<Object> task = new FutureTask<Object>(new MyCallable()); new Thread(task).start(); System.out.println("task return : " + task.get().toString()); //get方法会一直阻塞,直到这个线程也就是call方法执行完毕 //可以通过调用isDone()来异步的询问是否已经完成。 } catch (InterruptedException e) { e.printStackTrace(); } catch (ExecutionException e) { e.printStackTrace(); } }
还有另外一种方式可以使用
public void test2(){ ExecutorService newCachedThreadPool = Executors.newCachedThreadPool(); Future<Object> future = newCachedThreadPool.submit(new MyCallable()); try { //同样可以通过future.isDone()来异步的知道线程是否已经处理完毕 System.out.println(future.get().toString()); }catch (Exception e) { e.printStackTrace(); } finally { newCachedThreadPool.shutdown(); } }
通过上面的例子,我们知道了可以通过callable得到一个线程的返回值了,那么使用callable算多线程吗?
其实第一个例子的一行代码已经暴露出他有多线程的特性了
new Thread(task).start();
看看这个task是什么的东西
public class FutureTask implements RunnableFuture //是RunnableFuture的一个实现 public interface RunnableFuture extends Runnable, Future //是Runnable 的子接口,这就是为什么可以放入Thread类中 // 同时他又有future的特性,得到返回值
为了彻底看清Future到底有什么,下面接口就是Future的完整定义了
public interface Future { public abstract boolean cancel(boolean flag); public abstract boolean isCancelled(); public abstract boolean isDone(); public abstract Object get() throws InterruptedException, ExecutionException; public abstract Object get(long l, TimeUnit timeunit) throws InterruptedException, ExecutionException, TimeoutException; }
现在知道了Callable是借助Runnable来实现多线程的功能,所以说它是多线程也说的过去。那么它是如何获得返回值的呢?
我们都知道线程的启动方法是start方法,然后线程内部调用了run()方法
public void run() { sync.innerRun(); } protected void set(Object obj) { sync.innerSet(obj); } public Object get() throws InterruptedException, ExecutionException { return sync.innerGet(); }
我们的调用都深入到了sync的方面里面去了。接下来
void innerRun() { if(!compareAndSetState(0, 1)) return; runner = Thread.currentThread(); if(getState() == 1) { Object obj; try { obj = callable.call(); //这时候调用我们覆写的call方法了 } catch(Throwable throwable) { setException(throwable); return; } set(obj);//执行完之后将结果放入存起来 } else { releaseShared(0); } }
如何存,很简单,存入事先准备好的属性中
void innerSet(Object obj) { int i; do { i = getState(); if(i == 2) return; if(i == 4) { releaseShared(0); return; } } while(!compareAndSetState(i, 2)); result = obj;//这么存的 releaseShared(0); done(); }
如何取
Object innerGet() throws InterruptedException, ExecutionException { acquireSharedInterruptibly(0); if(getState() == 4) throw new CancellationException(); if(exception != null) throw new ExecutionException(exception); else return result;
相关推荐
Java多线程设计模式上传文件Java多线程设计模式上传文件Java多线程设计模式上传文件Java多线程设计模式上传文件Java多线程设计模式上传文件Java多线程设计模式上传文件Java多线程设计模式上传文件Java多线程设计模式...
### Java多线程操作数据库:深入解析与应用 在当今高度并发的应用环境中,Java多线程技术被广泛应用于处理数据库操作,以提升系统的响应速度和处理能力。本文将基于一个具体的Java多线程操作数据库的应用程序,深入...
Java多线程读大文件 java多线程写文件:多线程往队列中写入数据
Java多线程是Java编程中的重要概念,尤其在如今的多核处理器环境下,理解并熟练掌握多线程技术对于提高程序性能和响应速度至关重要。本资料详细讲解了Java多线程的原理,并提供了丰富的实战代码,非常适合Java初学者...
在Java编程中,多线程处理是提升程序性能和效率的重要手段,特别是在处理大量数据库数据时。本主题将深入探讨如何使用Java的并发包(java.util.concurrent)来实现多线程对数据库数据的批量处理,包括增、删、改等...
### Java多线程分页查询知识点详解 #### 一、背景与需求分析 在实际的软件开发过程中,尤其是在处理大量数据时,如何高效地进行数据查询成为了一个关键问题。例如,在一个用户众多的社交平台上,当用户需要查看...
《汪文君JAVA多线程编程实战》是一本专注于Java多线程编程的实战教程,由知名讲师汪文君倾力打造。这本书旨在帮助Java开发者深入理解和熟练掌握多线程编程技术,提升软件开发的效率和质量。在Java平台中,多线程是...
在Java编程中,多线程查询数据库是一种常见的优化策略,特别是在处理大数据量或者需要并行执行多个查询时。本文将详细探讨如何利用Java的多线程技术和线程池来实现并发查询数据库,以及相关的文件`BatchDataUtil....
在本文中,我们将深入浅出Java多线程编程的世界,探索多线程编程的基本概念、多线程编程的优点、多线程编程的缺点、多线程编程的应用场景、多线程编程的实现方法等内容。 一、多线程编程的基本概念 多线程编程是指...
Java多线程是Java编程中的重要概念,它允许程序同时执行多个任务,极大地提升了程序的效率和性能。在Java中,实现多线程有两种主要方式:通过实现Runnable接口或者继承Thread类。本案例将深入探讨Java多线程中的关键...
Java多线程是Java编程中的一个重要概念,它允许程序同时执行多个任务,提高了程序的效率和响应速度。在Java中,实现多线程有两种主要方式:继承Thread类和实现Runnable接口。 1. 继承Thread类: 当我们创建一个新...
《Java多线程编程实战指南》这本书深入浅出地讲解了Java多线程的核心概念和实战技巧,分为核心篇和设计模式篇,旨在帮助开发者掌握并应用多线程技术。 1. **线程基础** - **线程的创建**:Java提供了两种创建线程...
在Java编程中,多线程技术是处理大数据批量导入或导出的重要手段。它能有效提升程序执行效率,尤其在数据库操作这样的I/O密集型任务中。本项目以"java多线程实现大批量数据导入源码"为题,旨在通过多线程策略将大量...
在Java编程中,多线程并发是提升程序执行效率、充分利用多核处理器资源的重要手段。本文将基于"java 多线程并发实例"这个主题,深入探讨Java中的多线程并发概念及其应用。 首先,我们要了解Java中的线程。线程是...
Java多线程编程实战指南(核心篇) 高清pdf带目录 随着现代处理器的生产工艺从提升处理器主频频率转向多核化,即在一块芯片上集成多个处理器内核(Core),多核处理器(Multicore Processor)离我们越来越近了――如今...
在Java编程领域,多线程是一项至关重要的技术,它允许程序同时执行多个任务,从而提高系统资源的利用率和程序的响应速度。这份“JAVA多线程编程技术PDF”是学习和掌握这一领域的经典资料,涵盖了多线程的全部知识点...
Java多线程学习Java多线程学习Java多线程学习Java多线程学习Java多线程学习Java多线程学习Java多线程学习Java多线程学习Java多线程学习Java多线程学习Java多线程学习Java多线程学习Java多线程学习Java多线程学习Java...
JAVA多线程端点续传下载JAVA多线程端点续传下载JAVA多线程端点续传下载JAVA多线程端点续传下载JAVA多线程端点续传下载JAVA多线程端点续传下载JAVA多线程端点续传下载JAVA多线程端点续传下载JAVA多线程端点续传下载...
Java多线程机制是Java编程中至关重要的一部分,它允许程序同时执行多个任务,提升应用程序的效率和响应性。以下是对各个知识点的详细说明: 9.1 Java中的线程: Java程序中的线程是在操作系统级别的线程基础上进行...
Java的多线程能力是其强大之处,使得开发者能够在同一时间执行多个任务,提高程序效率。本指南将通过实例分析和实践演练,让你深入理解多线程的原理与应用。 首先,我们要了解Java中的线程模型。Java通过Thread类来...