一、synchronizedjava
所重入场景:算法
继承关系的类,子类调用父类的方法----------线程安全安全
带有synchronized关键字的方法互相调用----------线程安全并发
二、volatilejvm
做用:是变量在多个线程中可见,当改变变量值时(注意,改变的是主内存的值),每一个线程的工做内存仍是原先的值;性能
强制线程到主内存(共享内存)中去读,而不是去线程的私有内存中去读,从而实现多个线程中可见。优化
注意:此关键没有原子性,只有可见性,不能替代synchronized关键字的同步性spa
三、Atomic...线程
具备原子性,有boolean、Integer类型等;可是使用次关键字不能保证屡次操做的原子性,只能保证此方法的原子性orm
四、线程之间的通讯
使用wait和noyify方法实现线程之间的通讯,两个方法都是Object的方法
wait和notify必须配合synchronized关键字使用,wait方法释放锁,notify方法不释放锁
五、java堆
有新生代和老年代
新生代:ende区、s0区和s1区(或者form区和to区)
ende区存放新生(第一次建立)的对象,每次发生GC,对象的年龄都会增大,这是对象会进入s0或者s1区,默认当
对象年龄满15以后,若对象还继续被引用,则会分配到老年代,s0和s1区大小相等而且角色能够相互转换
六、垃圾收集算法
引用计数算法:在对象被引用时计数器加1,而引用失去计数器减1;缺点,没法处理对象被循环引用的状况,而且每次进行加减操做比较浪费性能;
标记清除法:顾名思义,就是标记被引用的对象和清除全部未被标记的引用对象;缺点,会产生大量的空间碎片,浪费空间;
复制算法:主要用于新生代,对象存放在s0或者s1区,每次只会使用一块区域,在垃圾回收时,将存活的对象(未进入老年代的对象)复制到s1或者s0区,而后清空s0或者s1区;
标记压缩法:在标记清除法基础之上作了优化,主要解决的空间碎片的问题;把存活对象压缩到内存的一端,而后进行垃圾清理(jvm中老年代的GC就是使用的标记压缩法);
七、分区算法
把内存划分为N个区域,每一个区域均可以独立使用,解决了GC时候扫描整块内存所消耗的性能,只须要清理某块区域;
八、TLAB区(Thread Local Allocation Buffer)