官术网_书友最值得收藏!

Event loop ordering, phases, and priorities

The event loop proceeds through phases, and each phase has a queue of events to process. From the Node documentation:

The phases relevant to developers are the following:

  • Timers: Callbacks deferred to some time in the future specified in milliseconds, such as setTimeout and setInterval
  • I/O callbacks: Prepared callbacks returned to the main thread after being delegated to Node's managed thread pool, such as filesystem calls and network listeners
  • Poll/checkMainly the functions slotted on the stack according to the rules of setImmediate and nextTick

When data becomes available on a socket or other stream interface, we cannot simply execute our callback immediately. JavaScript is single-threaded, so results must be synchronized. We can't suddenly change the state in the middle of an event loop tick — this would create some of the classic multithreaded application problems of race conditions, memory access conflicts, and so on.

To learn more about how Node is bound to libuv and other core libraries, parse through the fs module code at: https://github.com/nodejs/node/blob/master/lib/fs.js. Compare the fs.read and the fs.readSync methods to observe the difference between how synchronous and asynchronous actions are implemented; note the wrapper callback that is passed to the native binding.read method in fs.read. To take an even deeper pe into the very heart of Node's design, including the queue implementation, read through the Node source at: https://github.com/joyent/node/tree/master/src. Follow FSEventWrap within fs_event_wrap.cc. Investigate the req_wrap class, a wrapper for the V8 engine, deployed in node_file.cc and elsewhere and defined in req_wrap.h.

Upon entering an event loop, Node, in effect, makes a copy of the current instruction queue (also known as stack), empties the original queue, and executes its copy. The processing of this instruction queue is referred to as a tick. If libuv, asynchronously, receives results while the chain of instructions copied at the start of this tick are being processed on the single main thread (V8), these results (wrapped as callbacks) are queued. Once the current queue is emptied and its last instruction has completed, the queue is again checked for instructions to execute on the next tick. This pattern of checking and executing the queue will repeat (loop) until the queue is emptied, and no further data events are expected, at which point the Node process exits.

Next, let's look at the event interfaces of Node.

主站蜘蛛池模板: 寿宁县| 开封市| 沂水县| 常州市| 萨迦县| 晋江市| 丰城市| 武功县| 松桃| 长丰县| 武山县| 上栗县| 玛多县| 多伦县| 永定县| 梧州市| 札达县| 察雅县| 静宁县| 新巴尔虎右旗| 遂宁市| 上饶市| 和平县| 许昌县| 汶上县| 鄱阳县| 馆陶县| 荔波县| 邵东县| 南召县| 乡宁县| 蓬安县| 故城县| 久治县| 南阳市| 西和县| 新疆| 上犹县| 高邮市| 霸州市| 囊谦县|