05 synchronized其他概念

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();

}

}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值