- volatile关键字
- 原子性与原子类
- 多线程并发相关工具
- 正则表达式
- Lambda表达式
- Streaml流式编程
1、volatile关键字:对于线程共享变量存储空间并非在线程私有空间,而是存储在主内存中,每个线程生成该变量的副本到线程私有空间中,当多个线程同时操作线程共享变量时如果不上锁(sychornized同步或者lock)会造成线程不安全。通过volatile关键字可以解决共享变量的可见性问题,即一个线程操作共享变量完成后,会通知其他线程去主内存中重新生成新的副本,并且自己也会将新值写入主内存中。
2、原子性:我们常说的事件的原子性是指完成该事件的多个步骤要么全部成功,要么全部失败,不会完成一部分失败一部分。上述所说的volatile关键字只能保证共享变量在多个线程之间的可见性问题,并不能解决原子性问题,可以理解为一个线程在操作共享变量的时候其他线程可以中途也可以操作。
3、原子类:原子类对象可以保证线程共享变量同时只有一个线程在操作。确保了原子性
以AutomicInteger为例:类对象有以下常用方法:
自增并返回自增前的值
自增并返回自增后的值
原子类的底层其实是采用CAS(乐观锁)机制实现。
CAS:compare and swap ,比较并交换。有三个重要参数 :地址值、旧的期望值、需要修改的新值。线程拿到地址后去那实际值与旧的期望值相比,如果不同,会把自身的旧的期望值改成实际值,这个过程称为自旋。如此反复,直到旧的期望值与实际值相等,相等意味着无其他线程在修改此共享变量,则把该变量改成需要修改的新值。
4、常用并发工具:
hash