java多线程编程中,尤其关注的是线程同步的问题。
java中,所有的运算都是原子性的,除了long、float型数据(占两个字节),Volatile关键字可以确保这两种类型的数据操作保持原子性。
为了防止多个线程同时访问共享数据导致不一致的问题,java引入了synchronized关键字来实现同步锁。只有当线程获得同步锁时才能运行。
synchronized主要修饰作用有3种:
1)自定义同步锁
private byte[] lock= new byte[0];
Public void change() {
Synchronized(lock) {
}
}
2)对象同步锁:
Synchronized(this) {
}
或者
void method(){
}
3)类同步锁:
Synchronized static void method(){
}
或者
Synchronized (Clazz.class){
}
这3种类型实现的同步效果不一样。前2种,同一时刻,同一个对象的同步代码是不可以被同时访问的,而不同对象之间的同步方法是互不干扰的。第3种,同一时刻,被修饰部分只有一个对象可以运行。
所有的java对象都有一把锁,这也是每个java对象可以使用wait、notify、nitifyAll方法的原因。
大家熟知的操作系统进程运行状态图:
图中的线程状态都有相应的java方法与之对应:
1)New状态:java中用new关键字初始化一个线程。
2)ready状态:java中调用线程的start方法。
3)running状态:java中的run方法,jvm线程调度程序从可运行池中选择一个线程作为当前线程时线程所处的状态。这也是线程进入运行状态的唯一一种方式。
4)wait状态:调用java锁的wait方法,释放锁,进入等待状态。此时,该线程需要java锁的notify方法通知,方可进入ready状态。
5)sleep状态:java中Thread.sleep()静态方法强制当前正在执行的线程休眠,当睡眠时间到期,则返回到ready状态。
6)stop状态:java中的run方法结束。线程一旦死亡,就不能复生。