您的位置:首页 >深入探讨Java并发集合的机制和实现
发布于2024-12-25 阅读(0)
扫一扫,手机访问

在多线程编程中,多个线程可能同时访问和修改共享数据,这可能导致数据不一致或程序崩溃。为了解决这个问题,Java 提供了并发集合类,这些集合类实现了线程安全,可以确保在多线程环境下对数据的并发访问和修改是安全的。
CopyOnWriteArrayList 是一个线程安全的 ArrayList 实现,它使用写时复制的策略来保证线程安全。在写时复制策略中,当一个线程试图修改 CopyOnWriteArrayList 时,会创建一个新的 ArrayList 实例,并将原有集合中的元素复制到新的实例中。然后,对新实例进行修改,原有集合保持不变。这种策略保证了在多线程环境下对 CopyOnWriteArrayList 的修改是原子的,不会导致数据不一致。
import java.util.concurrent.CopyOnWriteArrayList;
public class CopyOnWriteArrayListExample {
public static void main(String[] args) {
CopyOnWriteArrayList<String> list = new CopyOnWriteArrayList<>();
list.add("Item 1");
list.add("Item 2");
list.add("Item 3");
// 创建一个新的线程并尝试修改 list
Thread thread = new Thread(() -> {
list.add("Item 4");
});
thread.start();
// 主线程继续对 list 进行修改
list.add("Item 5");
// 打印最终的 list
System.out.println(list);
}
}
输出结果:
import java.util.concurrent.ConcurrentHashMap;
public class ConcurrentHashMapExample {
public static void main(String[] args) {
ConcurrentHashMap<String, Integer> map = new ConcurrentHashMap<>();
map.put("Item 1", 1);
map.put("Item 2", 2);
map.put("Item 3", 3);
// 创建一个新的线程并尝试修改 map
Thread thread = new Thread(() -> {
map.put("Item 4", 4);
});
thread.start();
// 主线程继续对 map 进行修改
map.put("Item 5", 5);
// 打印最终的 map
System.out.println(map);
}
}
输出结果:
import java.util.concurrent.ConcurrentLinkedQueue;
public class ConcurrentLinkedQueueExample {
public static void main(String[] args) {
ConcurrentLinkedQueue<String> queue = new ConcurrentLinkedQueue<>();
queue.add("Item 1");
queue.add("Item 2");
queue.add("Item 3");
// 创建一个新的线程并尝试修改 queue
Thread thread = new Thread(() -> {
queue.add("Item 4");
});
thread.start();
// 主线程继续对 queue 进行修改
queue.add("Item 5");
// 打印最终的 queue
System.out.println(queue);
}
}
输出结果:
[Item 1, Item 2, Item 3, Item 5, Item 4]
在这个例子中,主线程和新线程同时对 queue 进行修改,但由于 ConcurrentLinkedQueue 使用 CAS 操作的策略,因此这两个线程的修改都是原子的,不会导致数据不一致。
下一篇:详解Java中的插入排序算法
售后无忧
立即购买>office旗舰店
售后无忧
立即购买>office旗舰店
售后无忧
立即购买>office旗舰店
售后无忧
立即购买>office旗舰店
正版软件
正版软件
正版软件
正版软件
正版软件
1
2
3
7
9