static:
1、修饰成员变量,通过修饰类的属性,将成员变量所属由对象变为类,从而实现所有对象对该变量的共享;
2、修饰成员方法,将其变为类方法,可以直接使用“类.方法”的方式调用,而不用new一个新对象,通常用于工具类;
3、静态方法块,将多个类成员放在一起初始化,被static修饰的方法将在类加载过程中优先初始化;
4、静态导包用法,将类方法直接导入当前类,从而直接使用方法名即可以使用方法
final:
1、修饰数据,表数据不可变,有且只有两个方法给final类型成员变量赋值①声明时赋值②构造方法赋值
2、修饰方法参数
3、修饰方法,表不能被重写
4、修饰类,表不能被继承
Volatile:
当一个变量被volatile修饰时,它可以保证修改的值立刻更新到主存中,每次读取该值都从主存中读取最新值。volatile变量能禁止指令重排序(内存屏障),支持happen-before,但他不是线程安全的
使用注意事项:①对变量写操作不依赖当前值(不如CAS,无原子性)②该变量未包含在具有其他变量的不变式中
常用用法:
1、修饰状态标记量(如AQS基类中的state)
2、double check(例如懒汉模式的单例对象用volatile修饰,防止多次创建)
synchronized:
作为锁保证线程安全,操作的原子性。用法有:
1、修饰实例方法,则对当前对象实例加锁,一个对象内多个synchronized方法相当于共用一个锁
2、修饰static方法,则对当前类加锁
3、修饰代码块,对固定对象加锁。(注意对string加锁时不要与同jvm内别的锁用的string一致,因为string在常量池中,value一样的string为同一个,会导致两个代码块共用一把锁)
java虚拟机对synchronized进行了优化,锁可分为无锁状态、偏向锁、轻量级锁、重量级锁四种状态
偏向锁:当第一个线程获取锁后,将在锁对象头上标记上锁,并记录当前获取锁线程,再次有线程请求锁时直接看是否为对象头中记录的线程,若是则直接放过,否则锁膨胀为轻量级锁
轻量级锁:采用CAS操作进行锁获取判定,若CAS失败,则膨胀为重量级锁
重量级锁:即原子化,每次线程进入代码都必须先获取锁,否则进入等待
synchronized与reentrantlock对比:
1、无需unlock操作,代码简洁安全
2、不支持响应中断,不支持trylock,不支持超时时间
3、仅能以wait/notify/notifyall进行线程间通信操作,不如reentrantlock的condition机制灵活
4、均为可重入锁
transient:
一个对象若需要被序列化,可实现Serilizable,则该对象所有变量、方法都可被实例化,若是对象中仅有部分想被实例化,则可将不需要序列化的变量用transient修饰,这个字段的生命周期仅存于调用者内存中而不会写到磁盘中持久化