显示锁【ReentrantLock可重入锁】和隐示锁【Synchronized】,模拟网络购票

同步锁 synchoronized :显示锁,锁开启关闭位置不显示;隐式锁
reentranlock:可重入锁,开关位置显示;显示锁【不仅同步代码块,还可以同步方法】
用可重入锁来取代sychoronized 同步代码块,执行效率更高;
一般用线程休眠来模拟扩大问题的发生概率可能性;

package cn.kgc.tyl.test1017;

import java.util.concurrent.locks.ReentrantLock;

/**
 * 同步锁 synchoronized :显示锁,锁开启关闭位置不显示;隐式锁
 * reentranlock:可重入锁,开关位置显示;显示锁【不仅同步代码块,还可以同步方法】 一般用线程休眠来模拟扩大问题的发生概率可能性;
 * 用可重入锁来取代sychoronized 同步代码块,执行效率更高;
 */
public class ShowSynchronizedLock implements Runnable {
	private int num;// 第几张票;
	private int count=10;// 总票数;
	private final ReentrantLock LOCK = new ReentrantLock();// 常量可重入锁;

	@Override
	public void run() {

		while (true) {
                  LOCK.lock();// 加锁,给同步代码块内容加锁 
			try {
				
				if (count <= 0) {
					return;
				}
                  Thread.sleep(200);
				count--;
				num++;
				System.out.println(Thread.currentThread().getName() + "--买了第" + num + "张票,还剩" + count + "张");

			} catch (Exception e) {
				e.printStackTrace();
			} finally {
				LOCK.unlock();// 解锁
			}
		}

	}

}
************************************************************************************************************************************1-1
package cn.kgc.tyl.test1017;

/**
 *
 * 测试同步锁
 */
public class TestShowSynchronizedLock {
	public static void main(String[] args) {
		ShowSynchronizedLock buyTicket = new ShowSynchronizedLock();// 共享数据,建立一个对象;
		Thread person1 = new Thread(buyTicket, "唐哥");
		Thread person2 = new Thread(buyTicket, "远哥");
		Thread person3 = new Thread(buyTicket, "黄牛哥");
		person1.start();
		person2.start();
		person3.start();
	}
}
*****************************************************************************************************************************************1-2
package cn.kgc.tyl.test1017;

/**
 *
 * 创建两个线程、进行抢票功能
 * 用while(ture)做循环判断时,就不用for循环了
 * 
 */
public class UnShowSynchronizedLock implements Runnable {
	
	private int count=10;//总票数
	private int num=0;//剩余票数
	@Override
	public void run() {
		while (true ) {
			synchronized (this) {
				if (count<=0) {
					return;
				}
				try {
					Thread.sleep(200);
				} catch (InterruptedException e) {
					
					e.printStackTrace();
				}
				count--;
				num++;
				System.out.println(Thread.currentThread().getName()+"买了第"+count+"张票,还剩"+num+"张 票");
			}
			
		}
	}

}
**********************************************************************************************************************************2-1
package cn.kgc.tyl.test1017;

public class TestUnShowSynchronizedLock {
	public static void main(String[] args) {
		UnShowSynchronizedLock buyTicket = new UnShowSynchronizedLock();
		Thread person1 = new Thread(buyTicket, "唐哥");
		Thread person2 = new Thread(buyTicket, "远哥");
		Thread person3 = new Thread(buyTicket, "黄牛哥");
		person1.start();
		person2.start();
		person3.start();
	}
}
***************************************************************************************************************************************2-2
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

m0_45442261

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值