java线程持锁状态下出现异常会释放锁

线程持锁状态下出现异常是否会释放锁?于是做了个实验:

public class LockTest {

public static class ThreadTest implements Runnable {

    private ReadWriteLock lock;
    private Lock readLock;
    private Lock writeLock;
    private int arg0;

    public void run() {
        writeLock.lock();
        try {
            String name = Thread.currentThread().getName();
            System.out.println(name + " start...");
            long now = System.currentTimeMillis();
            System.out.println(name + " start:" + now);
            //System.out.println(10 / arg0);
            try {
                Thread.sleep(5000);
            } catch (Exception e) {
                e.printStackTrace();
            }
            System.out.println(10 / arg0);
            long end = System.currentTimeMillis();
            System.out.println(name + " end:" + end);
            System.out.println(name + " use time:" + (end - now));
            System.out.println(name + " end...");

        } finally {
            writeLock.unlock();
        }

    }

    public ThreadTest(ReadWriteLock lock, int arg0) {
        this.lock = lock;
        this.readLock = lock.readLock();
        this.writeLock = lock.writeLock();
        this.arg0 = arg0;
    }
}

public static void test01() {
    ReentrantReadWriteLock lock = new ReentrantReadWriteLock();
    ThreadTest t1 = new ThreadTest(lock, 0);
    ThreadTest t2 = new ThreadTest(lock, 1);

    Thread thread1 = new Thread(t1, "th1");
    Thread thread2 = new Thread(t2, "th2");

    thread1.start();
    thread2.start();
}

public static void main(String[] args) {
    test01();
}

}
执行结果:
th1 start…
th1 start:1495075673822
th2 start…
[WARNING]
th2 start:1495075678827
java.lang.ArithmeticException: / by zero
at basic.simple.LockTest$ThreadTest.run(LockTest.java:38)
at java.lang.Thread.run(Thread.java:745)
10
th2 end:1495075683830
th2 use time:5003
th2 end…

结论:线程持锁状态下出现异常会释放锁。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
同步Java线程中用于保护共享资源,以确保同一时间只有一个线程可以访问该资源,从而避免数据竞争和并发问题。在Java中,可以使用synchronized关键字来实现同步的机制。 对于非静态的同步方法,可以是this对象或其他对象,要求是同一个对象。例如,使用关键字synchronized修饰的sell()方法,就在this对象上。 对于静态的同步方法,是当前类本身。因为静态方法可以在没有实例化对象的情况下使用,所以只能使用类来作为。可以使用synchronized修饰的静态方法m1()和m2()是示例。 除了直接在方法上使用synchronized关键字,还可以使用同步代码块来实现的机制。同步代码块的对象可以是this对象或其他对象。 当一个线程持有时,其他线程将无法获得该,它们将被阻塞,直到持有线程释放释放可以通过以下方式实现: 1. 当前线程的同步方法或同步代码块执行结束。 2. 当前线程在同步代码块或同步方法中遇到break或return语句。 3. 当前线程在同步代码块或同步方法中出现未处理的Error或Exception,导致异常结束。 4. 当前线程在同步代码块或同步方法中执行了线程对象的wait()方法,暂停当前线程,并释放。 需要注意的是,线程执行同步代码块或同步方法时,调用Thread.sleep()或Thread.yield()方法暂停当前线程的执行不释放。此外,使用suspend()方法将线程挂起也不释放

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值