对集合在客户端加锁

本文讨论了在并发环境中使用线程安全的集合类(如Vector, Stack, HashMap等)时,需要通过加锁确保操作的原子性,防止数据竞争和不一致性的问题。

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

使用线程安全的集合类,我们的操作并不一定是安全的,
因为客户端的操作并不是原子的,所以通常的办法是在客户端调用时加锁。
例如,Vector,Stack,HashMap等等。

eg:

public class UserManager {
 private List<String> userList = new ArrayList<String>();
 //在并发环境下需要加锁
 public /*synchronized*/ boolean addUser(String user){
  boolean succeed = false;
  synchronized (userList) {//加锁
   if(!userList.contains(user)){
    System.out.println(Thread.currentThread().getName() + "--->" +"我来了" + "--->" + user);
    succeed = userList.add(user);
   }
  }
  return succeed;
 }
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值