java中继承自Thread或者实现Runnable接口的类都是可用于执行多线程任务的类
要想得到任务执行的结果,可以向类的构造方法中传入类类型参数,例如
class AddThread implements Runnable{
private int a;//操作数a
private int b;//操作数b
public Object result;//结果
/**
* 构造方法
* @param a
* @param b
*/
public AddThread(int a,int b) {
super();
this.a = a;
this.b = b;
}
@Override
public void run() {
result=a+b;
}
}
用这种方式可以获得线程执行的结果,但是不知道线程何时执行完,也就是不知道何时去取执行结果
用下面这种方式,可以解决这个问题
import java.util.ArrayList;
import java.util.List;
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;
/**
* 加法线程类,做两个数的相加操作,返回结果
* @author admin
*
*/
class AddThread implements Callable<Object>{
private int id;//id字段,相当于线程名称
private int a;//操作数a
private int b;//操作数b
/**
* 构造方法
* @param a
* @param b
*/
public AddThread(int id,int a,int b) {
super();
this.id=id;
this.a = a;
this.b = b;
}
@Override
public Object call() throws Exception {
return a+b;
}
}
public class Test {
public static void main(String[] args) throws InterruptedException, ExecutionException {
ExecutorService exec = Executors.newCachedThreadPool();
//Future相当于是用来存放Executor执行的结果的一种容器
List<Future<Object>> results = new ArrayList<Future<Object>>();
for (int i=0;i<5;i++) {
results.add(exec.submit(new AddThread(i,i,i)));
}
for (Future<Object> fs:results) {
//fs.get()会等待线程返回出结果再执行
Object count=fs.get();
System.out.println(count);
}
exec.shutdown();
}
}
分享到:
相关推荐
多线程并行执行,汇总结果、多线程并行执行,汇总结果
易语言线程返回数据的方法源码,线程返回数据的方法,线程
NULL 博文链接:https://lf6627926.iteye.com/blog/1538301
java通过线程控制程序执行超时(新) 基本数据类型 反射 线程 超时
主线程等待子多线程(无结果返回)执行完成再继续执行
Java多线程实现数据切割批量执行,实现限流操作。 java线程池Executors实现数据批量操作。 批量异步Executors处理数据,实现限流操作,QPS限流。 线程池调用第三方接口限流实现逻辑。 案例适合: 1.批量处理大数据。...
向量在同一个块中用多个线程执行。本实验是启动一个线程块,这个线程块中启动的线程个数为10个。
它在调用进程的地址空间上创建一个线程,执行指定的函数,并返回新建立线程的句柄。 原型: HANDLE CreateThread( LPSECURITY_ATTRIBUTES lpThreadAttributes, DWORD dwStackSize, LPTHREAD_START_ROUTINE ...
需要注意的是,在实际的异步请求中,可能需要使用Future或其他方式来等待请求的完成,并获取返回结果。上面的示例只是演示了如何使用多线程来执行异步请求,具体的处理逻辑需要根据实际需求进行修改
http://blog.csdn.net/yangzhaomuma/article/details/51722779
通过多线程处理大批量耗时业务,并返回结果。当监测到线程池中存在空闲线程时则动态向线程池中添加新的任务,直到所有任务执行结束。Demo为自己写的测试使用,下载后可直接运行测试。
大家都知道实现多线程的2种方式,今天来讲讲Future实现具有返回值的线程。应用场景:前端调用时无需等待线程结束返回,线程结束后需进行其它操作如更新状态、通知kafuka等。
主要介绍了python使用threading获取线程函数返回值的实现方法,需要的朋友可以参考下
解决线程的死掉问题和超时问题特别好使,在Java中,如果需要设定代码执行的最长时间,即超时,可以用Java线程池ExecutorService类配合Future接口来实现。 Future接口是Java标准API的一部分,在java.util.concurrent...
取DOS命令返回结果,模拟DOS执行命令行
vc中获取一个线程的状态及返回值,VS2012工程,通过点击界面上按钮,启动一个判断线程,然后再这个判断线程启动一个工作线程,在判断线程里判断工作线程的工作状态
在本代码中演示了等待各个线程执行完毕然后在主线程根据各线程返回的值来进行后面的操作。 在本代码中,没有考虑效率问题,望大家见谅,数据也仅仅是为了程序而作,无意义。如果有错误或者不合适的地方,希望大家来...
目的:第二种方法有其独特的用法,就是可以做成任务槽的方式,做完任务就返回,然后exec进入事件循环,可以避免单一任务频繁创建线程的开销,又可以达到在另一个线程中进行任务的执行; 问题:在线程中,我想使用个...