2024-07-12
한어Русский языкEnglishFrançaisIndonesianSanskrit日本語DeutschPortuguêsΕλληνικάespañolItalianoSuomalainenLatina
public class TicketDemo {
// 票总数
private int ticketNum = 10;
/**
* 抢票
*/
public void getTicket() {
if (ticketNum <= 0) {
return;
}
System.out.println(Thread.currentThread().getName() + " 抢到一张票,剩余:" + ticketNum);
// 非原子性操作
ticketNum--;
}
/**
* 测试:20个人抢一张票
*/
public static void main(String[] args) {
TicketDemo ticketDemo = new TicketDemo();
for (int i = 0; i < 20; i++) {
new Thread(ticketDemo::getTicket).start();
}
}
}
Résultats du :
Vous pouvez voir qu'il apparaît problème de survente , il y a 10 tickets au total. Lorsque 20 fils récupèrent des tickets ensemble, 11 personnes semblent avoir récupéré les tickets. En effet, si les deux threads réussissent la vérification if en même temps.
Par conséquent, nous devons verrouiller l'opération du ticket pour garantir qu'un seul thread peut vérifier et effectuer la déduction du ticket en même temps.
public class TicketDemo {
// 锁
private static Object lock = new Object();
// 票总数
private int ticketNum = 10;
/**
* 抢票
*/
public void getTicket() {
synchronized (lock) {