多线程加锁

多线程加锁的几种方法
Object o
//先创建一个对象
Object o =new Object();
synchronized(o){ 代码块}

synchronized (o)
{
if(tickets>0) {
try {
Thread.sleep(10);
} catch (InterruptedException e) {
e.printStackTrace();
}
System.out.println(tickets);
System.out.println(Thread.currentThread().getName()+“出票:”+tickets);
tickets–;
}
通过synchronized 方法来加锁
public synchronized void method(){ 方法体;//这里面的内容就是加锁的。}
然后通过重写的run方法来调用这个方法
public synchronized void method() {

if (tickets > 0) {
try {
Thread.sleep(100);
} catch (InterruptedException e) {
e.printStackTrace();
}
System.out.println(Thread.currentThread().getName() + “卖出:” + tickets);
tickets–;
}

}
public void run() {
while (true) {
method();
}

}
同步方法也有锁不过这个锁不需要我们自己去创建new Object();但是这个锁也是一个对象。在非静态方法中这个锁就是this这个对象,因为在所有得到非静态方法中都存在。而静态方法中锁是字节码文件这个对象。也就是class对象获取Class对象的方式:类名.class;

其实上面两种方法差距不大都是通过对象来实现锁的, 在同步代码块中不需要手动的书写获取锁、释放锁的代码。但是,同步代码块在执行时底层还是会获取锁、释放锁还有就是通过加同步Lock 来实现

Lock是一个接口需要通过他的实现类ReentrantLock创建对象Lock L =new ReentrantLock();L.lock();代码块L.unlock();

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值