java-多线程持续

本文探讨了Java多线程中的线程状态,重点分析了volatile关键字的作用,包括解决内存可见性和指令重排问题。同时,介绍了线程安全的数据结构如 ConcurrentHashMap、CopyOnWriteArrayList 和 CopyOnWriteArraySet。还详细讲解了AtomicInteger的用法,并对比了volatile与synchronized在保证线程安全方面的区别。最后提到了在高并发环境下AtomicInteger的应用。
摘要由CSDN通过智能技术生成

线程状态

Thread.yield():提出释放CPU时间⽚的请求。不会释放锁,线程依然处于RUNNABLE状态,即调度权让给别⼈,但⽴刻可以回到竞争线程锁的状态。

  • Thread.sleep():调⽤后线程处于阻塞状态,注:线程状态处于BLOCKED或WAITING或TIME_WAITING这三种统称为堵塞状态。

线程安全的常用数据结构

  1. HashMap:ConcurrentHashMap
  2. ArrayList:CopyOnWriteArrayList
  3. Set:CopyOnWriteArraySet

关键字

- volatile

volatile只能用于修饰变量,不能用于修饰方法或代码块。
​当被volatile修饰的变量被读取的时候,是从主存读取,当被volatile修饰的变量被写入的时候,是写入到主存。
多数用于标记性作用

- volatile解决的问题

内存可见性问题
指令重排问题。

- volatile作用

保证共享变量的可见性。
保证共享变量使用时的有序性。

- 总结

synchronized 修饰方法或代码段。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值