Single thread JavaScript
JavaScript has a concurrency model based on event loop. Each message is processed completely before any other message is processed. This offers some nice properties when reasoning about your program, including the fact that whenever a function runs, it cannot be pre-empted and will run entirely before any other code runs (and can modify data the function manipulates).
runYourScript(); while (atLeastOneEventIsQueued) { fireNextQueuedEvent(); };
Let"s use setTimeout as a simple example:
let start = +new Date; setTimeout(function Task1(){ let end = +new Date; console.log(`Task1: Time elapsed ${end - start} ms`); }, 500); //500ms later,Task1 will be inserted into event queue // single thread setTimeout(function Task2(){ let end = +new Date; console.log(`Task2: Time elapsed ${end -start} ms`); /** * use while loop to delay the completion of the function for 3 seconds * this will block the execution of the next function in event loop * i.e. looping through the event queue has to happen after the main thread finishes its task */ while(+new Date - start < 3000) {} }, 300); //300ms later,Task2 will be inserted into event queue while(+new Date - start < 1000) {} //main thread delay completion for 1 second console.log("main thread ends"); //output: //main thread ends //Task2: Time elapsed 1049 ms //Task1: Time elapsed 3000 ms
setTimeout will put the first argument(type Function) into event queue. Here is what happens in the code above:
300ms later,Task2 is inserted into event queue.
500ms later,Task1 is inserted into event queue.
1 second later, the main thread finishes, "main thread ends" is printed on the console.
The main thread will loop through the event queue when it finishes its job at hand. The first function in the event queue is Task2(as it"s inserted first). So Task2 is fetched and executed, resulting the console output "Task2: Time elapsed 1049 ms". The elapsed time you see may differ as setTimeout is not exactly dealying the execution of your function. All it does is to put the function into the event queue with the delay you set. When the function will be executed depends on the queueing functions in the event queue, as well as the status of the main thread (whether it has remaining task running).
Execute Task1 after Task2 finishes.
What are Asynchronous functionsAsynchronous functions in JavaScript usually can accept a last parameter of function type (it"s usually called callback) and the callback will be inserted into event queue when the function completes. As the callback is in event queue, the function is NON-BLOCKING. Asynchronous functions can guarantee the following unit test will always pass:
let functionHasReturned = false; asyncFunction(() => { console.assert(functionHasReturned); }); functionHasReturned = true;
Note that NOT all functions with a callback parameter are asynchronous. E.g. Array.prototype.forEach is synchronous.
let before = false; [1].forEach(() => { console.assert(before); }); before = true;Exceptions in asynchronous functions
Since the callback function is put in the event queue and executed later with it"s own invoking context, wrapping the asynchronous functions with try-catch mechanism won"t be able to catch the exception from the callback.
try { setTimeout(() => { throw new Error("callback error"); }, 0); } catch (e) { console.error("caught callback error"); } console.log("try-catch block ends");
In the example, the exception thrown in the callback is not caught by our own program (i.e. the catch block - no "caught callback error" is printed on the console). We can catch these uncaught exceptions with window.onerror in brower and process.uncaughtException in Node.
If we want to deliberately catch the error, as we should always do, we can do it in the callback. E.g.
let fs = require("fs"); fs.readFile("abc.txt", function(err, data) { if (err) { return console.error(err); }; console.log(data); });Reference
Async JavaScript
NoticeIf you want to follow the latest news/articles for the series of reading notes, Please 「Watch」to Subscribe.
文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請注明本文地址:http://m.specialneedsforspecialkids.com/yun/93393.html
摘要:我們可以看到,百度也在頭部引入了一些文件,這些文件引入的方式與的做法差不多,都在引入外部資源的標簽上添加了屬性,除了第一個文件沒有那樣做。 更好閱讀體驗,請訪問dreamapple.me 我們今天來聊一聊關(guān)于JavaScript文件的引入位置的問題;大家在平時的Web開發(fā)中有沒有想過這樣一個問題,那就是我應該在文檔的頭部(也就是標簽內(nèi)部里面)引入所需要的JavaScript文件還是應該...
摘要:此外,在不違背原作者本意前提下,為了更直觀的表達,部分內(nèi)容將采用意譯,而非直譯。開始閱讀深入理解 此書是 TypeScript Deep Dive 的中文翻譯版,感謝作者 Basarat 的付出。 Why showImg(https://segmentfault.com/img/remote/1460000016154927?w=2050&h=810); 數(shù)據(jù)來源:npm 包下載量 ...
閱讀 3062·2023-04-26 00:40
閱讀 2401·2021-09-27 13:47
閱讀 4255·2021-09-07 10:22
閱讀 2971·2021-09-06 15:02
閱讀 3316·2021-09-04 16:45
閱讀 2504·2021-08-11 10:23
閱讀 3607·2021-07-26 23:38
閱讀 2907·2019-08-30 15:54