工作中常用的创建线程的三种方式:
1、继承Thread类
2、实现Runnable接口
3、实现Callable
样例:
(1)继承Thread类
class MyThread extends Thread{
@Override
public void run() {
System.out.println("继承Thread");
}
}
(2)实现runnable接口
class MyRunnable implements Runnable{
@Override
public void run() {
System.out.println("实现了Runnable");
}
}
为什么有了上面两种方式创建线程,为啥还要第三种实现callable接口呢?
我们观察里面的run方法,返回的都是void,也就是说这两种方式都不能返回处理后的结果。但是Callable接口的出现可以有效地解决这一问题。
(3)实现callable接口
1、创建一个实现了Callable接口的线程
class MyCallable implements Callable<Integer>{
System.out.println(Thread.currentThread().getName()+"进入callable");
@Override
public Integer call() throws Exception {
int value = 1;
return value;
}
}
2、使用线程
public static void main(String[] args) throws Exception{
FutureTask<Integer> task = new FutureTask<>(new MyCallable());
Thread thread = new Thread(task,"线程A");
thread.start();
System.out.println("Callable返回的结果是:"+task.get());
}
Future是一个函数式接口,大家可以自行百度。Future还有以下方法:
(1)cancel方法用来取消任务,如果取消任务成功则返回true,如果取消任务失败则返回false。
参数mayInterruptIfRunning表示是否允许取消正在执行却没有执行完毕的任务,如果设置true,则表示可以取消正在执行过程中的任务。如果任务已经完成,则无论mayInterruptIfRunning为true还是false,此方法肯定返回false,即如果取消已经完成的任务会返回false;
如果任务正在执行,若mayInterruptIfRunning设置为true,则返回true,
若mayInterruptIfRunning设置为false,则返回false;
如果任务还没有执行,则无论mayInterruptIfRunning为true还是false,肯定返回true。
(2)isCancelled方法表示任务是否被取消成功,如果在任务正常完成前被取消成功,则返回 true。
(3)isDone方法表示任务是否已经完成,若任务完成,则返回true;
(4)get()方法用来获取执行结果,这个方法会产生阻塞,会一直等到任务执行完毕才返回;
(5)get(long timeout, TimeUnit unit)用来获取执行结果,如果在指定时间内,还没获取到结果,就直接返回null。