淘宝面试题之CountDownLatch应用

本文深入探讨了在淘宝面试中常见的CountDownLatch应用场景,通过实例解析其使用方法和关键特性,帮助读者理解如何在多线程环境中协调任务执行。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

 XML Code 
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
package com.lyzx.day01;

import java.util.ArrayList;
import java.util.List;
import java.util.concurrent.CountDownLatch;

/**
 * 曾经的面试题:(淘宝?)
 * 实现一个容器,提供两个方法 add,size
 * 写两个线程,线程1添加10个元素到容器中,线程2实现监控元素的个数,当个数到5个时,线程2给出提示并结束
 *
 */
public class T5{
    public static void main(String[] args) {
        CountDownLatch latch = new CountDownLatch(1);
        Arr<Object> arr = new Arr<Object>(latch);
        
        new Thread(new R2(latch)).start();
        new Thread(new R1(arr)).start();
    }
}

class Arr<E>{
    private CountDownLatch latch;
    private List<E> arr = new ArrayList<E>();
    
    public Arr(CountDownLatch latch){
        this.latch=latch;
    }
    
    public synchronized boolean add(E e){
        boolean v = arr.add(e);
        try {
            Thread.sleep(300);
        } catch (InterruptedException e1) {
            e1.printStackTrace();
        }
        
        if(5 == size()){
            latch.countDown();
        }
        System.out.println("======"+size());
        return v;
    }
    
    public synchronized int size(){
        return arr.size();
    }
}

class R1 implements Runnable{
    private Arr<Object> arr;
    public R1(Arr<Object> arr){
        this.arr=arr;
    }
    
    @Override
    public void run(){
        for(int i=0;i<10;i++){
            arr.add(new Object());
        }
    }
}

class R2 implements Runnable{
    private CountDownLatch latch;
    
    public R2(CountDownLatch latch){
        this.latch= latch;
    }
    
    @Override
    public void run(){
        try {
            latch.await();
        } catch (InterruptedException e) {
            e.printStackTrace();
        }
        System.out.println("now 。。。。。over..");
    }
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值