美文网首页
Js 线程锁 navigator.locks

Js 线程锁 navigator.locks

作者: 板栗炖牛肉 | 来源:发表于2024-07-17 16:06 被阅读0次

前言

  • 环境 Baseline 2022
  • 检查控制台# navigator.locks
  • 文档链接
  • https链接,本地localhost地址测试,不支持http
  • 浏览器不同选项卡线程锁

解决方案

  • 主要函数navigator.locks.request(锁名称, async func)
const Test = () => {

    const implement = (name) => {
        // navigator.locks.request(name, asynchronous); //与下方函数相等
        navigator.locks.request(name, {mode: "exclusive"}, asynchronous);

        async function asynchronous(lock) {
            console.info('步入1', lock)
            await new Promise((r, j) => {
                console.info('步入2', lock)
                setTimeout(() => {
                    r();
                }, 3000)
            }).then((value) => {

            }).finally(() => {
                console.info('模拟完成')
            })
        }
    }

    return (
        <div>
            <Button onClick={() => implement("111")}>测试锁1</Button>
            <Button onClick={() => implement("222")}>测试锁2</Button>
        </div>
    );
}

相关文章

  • NodeJs多线程、多进程、定时任务

    JS是单线程语言,减少了线程间切换的开销,且不用考虑锁的问题,因此适合IO密集型项目。JS的单线程,其实指的是js...

  • 4.0.6.守护线程,线程死锁

    守护线程会随着主线程的结束而结束DaemonThread 线程 1, 线程 2,锁1,锁2 线程1 有锁1,想拿锁...

  • 悲观锁:一个线程得到锁,其它线程挂起,synchronized 乐观锁:一个线程得到锁,其它线程不断重试, cas...

  • sleep,wait, join yield

    锁池:所有需要竞争同步锁的线程都会放在锁池中,当一个线程得到锁后,其他线程都会在锁池中等待,当线程释放锁之后,其他...

  • 并发编程-线程

    线程 GIL 守护线程 线程锁(互斥锁 and 递归锁) 信号量 事件 条件 定时器 1.线程: 特点在多线程的操...

  • 深入理解AQS(二)- 共享模式

    共享锁与独占锁 独占锁被某个线程持有时,其他线程只能等待当前线程释放后才能去竞争锁,而且只有一个线程能竞争锁成功。...

  • iOS中各种锁的性能对比

    自旋锁 与 互斥锁 自旋锁 (spin lock): 如果一个线程需要获取自旋锁,该锁已经被其他线程占用,该线程不...

  • 死锁

    什么是死锁 简单的说:线程1持有A锁,线程2持有B锁;线程1尝试获取B锁,线程2尝试获取A锁。两个线程各持有了一把...

  • 公平锁和非公平锁-ReentrantLock是如何实现公平、非公

    1、什么是公平锁与非公平锁 公平锁:公平锁就是保障了多线程下各线程获取锁的顺序,先到的线程优先获取锁。非公平锁:非...

  • 2020-03-11 公平锁与非公平锁

    补: 公平锁:多个线程情况下排队,先到先获得锁 非公平锁:当锁被释放后,所有线程竞争锁,抢到的线程就会获得锁 非公...

网友评论

      本文标题:Js 线程锁 navigator.locks

      本文链接:https://www.haomeiwen.com/subject/gwblhjtx.html