public class DeadLock {
public static String resource1="df";//资源一
public static String resource2="df";//资源二
/**
* @param args
*/
public static void main(String[] args) {
// TODO Auto-generated method stub
Thread thread1 =new Thread(){
public void run(){
synchronized(resource1){
System.out.println("资源一已占用,停一会之后再占用资源二");
try {
Thread.sleep(5000);
} catch (InterruptedException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
synchronized(resource2){
System.out.println("现在已占用资源二");
}
}
};
Thread thread2 = new Thread(){
public void run(){
synchronized(resource2){
System.out.println("资源二已占用,停一会之后再占用资源一");
try {
Thread.sleep(300);
} catch (InterruptedException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
synchronized(resource1){
System.out.println("占用资源一去");
}
}
};
thread1.start();
System.out.println("线程一执行中....");
thread2.start();
System.out.println("线程二执行中....");
}
}
上边的例子是不构成死锁的,因为执行顺序的先后总是有误差的, 但是我的大体的理解就是那样 synchronized关键字就是说“占用某个资源并给他上锁”。
就好一两个人A有苹果,B柚子,但是A想吃柚子,B想吃苹果,A就说了,你先给我柚子我就给你苹果,B同时也说,你先给我苹果我再给你柚子,结果两个人谁也不让步,就僵持在那里。