我是靠谱客的博主 称心人生,最近开发中收集的这篇文章主要介绍乐观锁和悲观锁解决leetcode的1117题目H2O生成问题,觉得挺不错的,现在分享给大家,希望可以做个参考。

概述

使用乐观锁+Thread.yield实现

package com.gavin;
import org.junit.jupiter.api.Test;
import java.util.concurrent.Semaphore;
public class LockTest {
private static final String strs = "HHOOHHOHOHHH";
private volatile int hNum = 0;
@Test
public void test() throws InterruptedException {
Thread t1 = new Thread(() -> {
try {
for (char ch : strs.toCharArray()
) {
if (ch != 'H') {
continue;
}
System.out.println("线程:" + Thread.currentThread().getName() + ch);
hNum++;
while (hNum == 2) {
Thread.yield();
}
}
} catch (Exception e) {
e.printStackTrace();
}
});
Thread t2 = new Thread(() -> {
try {
for (char ch : strs.toCharArray()) {
if (ch != 'O') {
continue;
}
System.out.println("线程" + Thread.currentThread().getName() + ch);
while (hNum != 2) {
Thread.yield();
}
hNum = 0;
}
} catch (Exception e) {
e.printStackTrace();
}
});
t1.start();
t2.start();
t1.join();
t2.join();
}
}

最后

以上就是称心人生为你收集整理的乐观锁和悲观锁解决leetcode的1117题目H2O生成问题的全部内容,希望文章能够帮你解决乐观锁和悲观锁解决leetcode的1117题目H2O生成问题所遇到的程序开发问题。

如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。

本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
点赞(33)

评论列表共有 0 条评论

立即
投稿
返回
顶部