04-Callable及常用辅助类

Callable

Callable类似于Runnable,然而Runnable不会返回结果,也不会抛出执行时的异常。
在这里插入图片描述

  static class Test1 implements Callable<String>{

        @Override
        public String call() throws Exception {
            System.out.println("call()");
            return "已调用";
        }
    }

实现Callable接口需要覆写其实现方法,其方法的返回值对应着参数V
启动Callable

        //new Thread(new Runnable()).start();
        //new Thread(new FutureTask<V>()).start();
        //new Thread(new FutureTask<Callable>()).start();
        Test1 test1=new Test1();
        FutureTask futureTask=new FutureTask(test1);//适配类
        new Thread(futureTask,"A").start();
        System.out.println(futureTask.get());//需等待,可能会产生阻塞

通过连接第三方适配类Futuretask启动Callable
结果:
在这里插入图片描述

countDownLatch

允许一个或多个线程等待直到其他线程执行完一组操作,用于计数
示例
当运行的线程数小于设定线程数,

 CountDownLatch countDownLatch=new CountDownLatch(6);//用于计数
        for (int i = 1; i <= 4; i++) {
            new Thread(()->{
                System.out.println(Thread.currentThread().getName()+"当前线程执行完毕");
                countDownLatch.countDown();//计数器减一
            },String.valueOf(i)).start();
        }
        countDownLatch.await();//计数器归零之后才向下操作
        System.out.println("所有线程执行完毕");

注意参数线程数和实际线程数的关系!
结果:
造成线程一直等待,无法达到设定线程数量
在这里插入图片描述
当运行的线程数大于设定线程数:
在这里插入图片描述
结果:

在这里插入图片描述
当运行的线程数等于设定线程数:
在这里插入图片描述

多线程无论顺序,所有线程执行完毕,计数器归零,才会继续往下执行。

CyclicBarrier

允许一组线程全部等待彼此达到共同屏障点的同步辅助,循环阻塞在涉及固定大小的线程方式很有用,屏障被称为循环。

当线程数大于或者小于设定的参数线程时,造成线程等待


/**
 * @author 
 * @Date 2022/7/18
 * @apiNote
 */
 CyclicBarrier cyclicBarrier=new CyclicBarrier(6,()->{
            System.out.println("所有线程已完成,准备就绪下一个步骤");
        });
        for (int i = 1; i <= 5; i++) {
            new Thread(()->{
                System.out.println(Thread.currentThread().getName()+"当前线程执行完毕");
                try {
                    cyclicBarrier.await();
                } catch (InterruptedException e) {
                    e.printStackTrace();
                } catch (BrokenBarrierException e) {
                    e.printStackTrace();
                }
            },String.valueOf(i)).start();
        }

执行:
在这里插入图片描述
循环次数改为8时:
在这里插入图片描述

结果:
在这里插入图片描述
只有设定线程数与运行线程数数量一样时:
在这里插入图片描述
结果:
在这里插入图片描述

Semaphore

一个计数信号量,在概念上,信号量维持一个许可证,如果有必要,每个Acquire()都会阻塞,直到许可证可用然后才能使用它。
例:


/**
 * @author 
 * @Date 2022/7/18
 * @apiNote
 */
        Semaphore semaphore=new Semaphore(3);
        for (int i = 0; i < 6; i++) {
            new Thread(()->{
                try {
                    System.out.println("初始许可数为3");
                    semaphore.acquire();
                    System.out.println(Thread.currentThread().getName()+"当前线程抢到许可,剩余许可"+semaphore.availablePermits());
                    TimeUnit.SECONDS.sleep(3);
                    semaphore.release();
                    System.out.println(Thread.currentThread().getName()+"当前线程释放许可,剩余许可"+semaphore.availablePermits());
                } catch (InterruptedException e) {
                    e.printStackTrace();
                }
            },String.valueOf(i)).start();
        }

结果:
在这里插入图片描述

用于限流,指定线程执行的个数,多个线程互斥作用。
semaphore.acquire()获得。如果已经满了,则等待,直到释放为止。
semaphore.release()释放。会将当前位置释放,唤醒等待线程。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值