ii)自制乐观锁:
例 2.2.1.2
package com;
public class Ticket_Opti_MarkToWin {
private int number=4;
private int numberVersion=0;
private synchronized int updAtom(int num,int verNum)
{
int flag;
if(numberVersion==verNum&&number>num){
return flag;
}
void buyOne()
{
/*前面的三句,都只是get,想改只有updAtom里面,
你的buyOne只有改对和不改的权利,没有改错的权利*/
int myVersion=numberVersion;
if(flag==1){
System.out.println("买一张成功");
}else{
System.out.println("已经进队等了一会,买一张失败");
}
}
void buyBatch(int num)
{
int myVersion=numberVersion;
int myNumber=number;
}
}
package com;
class MulThreMarkToWin extends Thread {
Ticket_Opti_MarkToWin ticOpti_MarkToWin;
}
class MulThreMarkToWinBatch extends Thread {
Ticket_Opti_MarkToWin ticOpti_MarkToWin;
}
public class TestConcurBuy_MarkToWin {
public static void main(String[] args) {
Ticket_Opti_MarkToWin ticOpti_MarkToWin=new Ticket_Opti_MarkToWin();
Thread t1 = new MulThreMarkToWin(ticOpti_MarkToWin);
Thread t2 = new MulThreMarkToWinBatch(ticOpti_MarkToWin);
Thread t3 = new MulThreMarkToWin(ticOpti_MarkToWin);
Thread t4 = new MulThreMarkToWin(ticOpti_MarkToWin);
t1.start();
t2.start();
t3.start();
t4.start();
}
}
更多请看:https://blog.youkuaiyun.com/qq_44638460/article/details/104137404
本文介绍了一种自制乐观锁的实现方式,通过版本号检查来确保并发操作的一致性。示例代码展示了如何在多线程环境下使用乐观锁进行票务系统的并发购买操作,避免了常见的竞态条件问题。
4182

被折叠的 条评论
为什么被折叠?



