Synchonized锁重入:
关键字synchronized拥有锁重入的功能,也就是在使用synchronized时,当一个线程得到了一个对象的锁后,再次请求此对象时是可以再次得到该对象的锁。
示例:
package edu.sdut.thread01;
/* * synchronized的重入 */ public class MyThread05 { public synchronized void method1() { System.out.println("method1..."); method2(); } public synchronized void method2() { System.out.println("method2..."); method3(); } public synchronized void method3() { System.out.println("method3..."); } public static void main(String[] args) { final MyThread05 m = new MyThread05(); Thread t1 = new Thread(new Runnable() {
@Override public void run() { // TODO Auto-generated method stub m.method1(); } }); t1.start(); } }
|
说明:对于web应用程序,异常释放锁的情况,如果不及时处理,很可能对你的应用程序业务逻辑产生严重的错误,比如你现在执行一个队列的任务,很多对象都去在等待第一个对象正确执行完毕再去释放锁,但是第一个对象由于异常的出现,导致业务逻辑没有正常执行完毕,就释放了锁,那么可想而知后续的对象执行的都是错误的逻辑。所以这一点要引起注意,在编写代码的时候,一定要考虑周全。
示例:
package edu.sdut.thread01; public class MyThread06 { private int i = 0; public synchronized void operation() { while(true) { try { i++; Thread.sleep(1000); System.out.println(Thread.currentThread().getName()+", i = " + i); if(i==10) { Integer.parseInt("a");//抛异常错误 //throw new RuntimeException(); } }catch(Exception e) { e.printStackTrace(); System.out.println("log info i = 10"); //throw new RuntimeException(); //如果抛出异常后停止后面的任务就抛出运行时异常 continue;//如果抛出异常后 继续后面的任务 就continue } } } public static void main(String[] args) { final MyThread06 m = new MyThread06(); Thread t = new Thread(new Runnable() { @Override public void run() { // TODO Auto-generated method stub m.operation(); } }); t.start(); } } |