发布于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旗舰店