各位观众,欢迎来到今天的“原子操作夜总会”,我是今晚的驻场谐星(兼你的编程讲师),咱们今天要聊的是JS里一个挺有意思的新玩意儿:Atomics.waitAsync。 你是不是觉得JS是单线程的,谈并发简直是天方夜谭?这话没错,但架不住人家标准委员会的人能折腾啊!他们想方设法在单线程的环境下模拟出并发的效果,Atomics.waitAsync就是其中一个重要的尝试。 为什么要搞出个Atomics.waitAsync? 首先,咱们得明白,JS的传统Atomics.wait是阻塞操作。这意味着,如果一个线程在等待某个条件满足,它就啥也干不了,直接卡死在那里。这在浏览器的主线程里简直是灾难性的,想象一下,你的网页因为一个Atomics.wait直接卡死,用户会怎么想?估计会直接关掉网页,然后把你拉黑。 所以,我们需要一种非阻塞的等待机制,让线程在等待的时候可以去做别的事情,等条件满足了再回来继续执行。Atomics.waitAsync就是为此而生的。 Atomics.waitAsync是个什么玩意儿? 简单来说,Atomics.waitAsync允许你在等待一个共享内存中的值发生变化时,不会阻 …