java 线程的可重入锁_java 多线程-可重入锁

可重入锁:锁可以连续使用

计数器+判断进入的线程是不是已经锁定的线程,如果是那就不用等待,直接使用

public class my {

public static void main(String[]args)

{

my m=new my();

m.test();

}

public void test()

{

synchronized(this)//第一次获得锁

{

while(true)

{

synchronized(this)//第二次获得锁,假如没有可重入锁,将会造成死锁

{

System.out.println("relock");

}

try {

Thread.sleep(1000);

} catch (InterruptedException e) {

// TODO Auto-generated catch block

e.printStackTrace();

}

}

}

}

}

手工实现:

public class my {

Lock lock=new Lock();

public void a() throws InterruptedException

{

lock.lock();

System.out.println(lock.getCount());

b();

lock.unlock();

System.out.println(lock.getCount());

}

public void b() throws InterruptedException

{

lock.lock();

System.out.println(lock.getCount());

//..

lock.unlock();

System.out.println(lock.getCount());

}

public static void main(String[]args) throws InterruptedException

{

my m=new my();

m.a();

Thread.sleep(1000);

System.out.println(m.lock.getCount());

}

}

class Lock{

//是否占用

private boolean isLocked=false;

private Thread lockedBy=null;//存储线程,如果是自身就不等了

private int count=0;

//使用锁

public synchronized void lock() throws InterruptedException

{

Thread t=Thread.currentThread();

while(isLocked&&lockedBy!=t)//如果被锁住了,且不是当前线程

{

wait();

}

isLocked=true;

lockedBy=t;

count++;

}

//释放锁

public synchronized void unlock()

{

if(Thread.currentThread()==lockedBy)

{

count--;

if(count==0)

{

isLocked=false;

notify();

lockedBy=null;

}

}

isLocked=false;

notify();

}

public int getCount() {

return count;

}

public void setCount(int count) {

this.count = count;

}

}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值