java并发编程:线程的三种创建方式

工作中常用的创建线程的三种方式:

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。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值