Parallel programming / Synchronization using JavaScript Web Workers

前端 未结 3 1605
悲哀的现实
悲哀的现实 2021-01-18 18:11

Are there any synchronization primitives like Barriers, Semaphors, Locks, Monitors, ... available in JavaScript / Web Workers or is there

相关标签:
3条回答
  • 2021-01-18 18:28

    Here you have a library based on jQuery made for that purpose: http://www.megiddo.ch/jcon-q-rency.

    Of course the model is not really identical to java.util.concurrent since we are not dealing with the same environment, as explained in the other answers...

    0 讨论(0)
  • 2021-01-18 18:29

    In short: no there aren't any synchronization primitives in javascript but there is also no need for them since JavaScript is inherently single threaded :). Workers can only access there own scope (no dom manipulation just calculations) and send messages to the main ui thread where the normal js resides. I'm not sure about the maximum count of workers but there sure is a limit, you could try it out in a browser :)

    Hope this helps!

    0 讨论(0)
  • 2021-01-18 18:31

    Web workers don't have a concept of shared memory; all messages that are passed between threads are copied. With that being said, you don't have Barriers, Semaphores, Locks, and Monitors, because you don't need them in the web worker model.

    The concept of shared memory was proposed back in Feb 2011 but the status is now wontfix due to developer complexity => https://lists.webkit.org/pipermail/webkit-unassigned/2011-February/287595.html

    There is also a nice blurb about web workers here. http://blogs.msdn.com/b/ie/archive/2011/07/01/web-workers-in-ie10-background-javascript-makes-web-apps-faster.aspx

    Hope this helps

    0 讨论(0)
提交回复
热议问题