线程安全问题本质是多线程并发访问共享变量时因操作非原子、内存不可见或执行顺序不确定导致结果错误;典型如count++被拆为load-add-save三步,易因线程抢占造成中间状态丢失。
线程安全问题,本质是多个线程并发访问同一共享变量时,因操作非原子、内存不可见或执行顺序不确定,导致最终结果与预期不符。
最直观的例子就是 count++ 操作:两个线程各执行 10000 次,理论上应得 20000,但实际输出常为 13000~19000 之间的随机值,且每次运行结果都不同。这是因为 count++ 在 JVM 层面被拆成三步——load(读)、add(加)、save(写),而线程可能在任意一步被抢占,造成中间状态丢失。
private static int counter,所有线程共享同一份内存,无保护即不安全HashMap、ArrayList 等非线程安全集合,在多线程 put/add 时可能引发死循环、数据覆盖或 ConcurrentModificationException
volatile 修饰实例字段,可能因指令重排序导致返回未初始化的对象关键在于同时满足四个条件:
只要缺一,就可能掉进线程安全陷阱。