本篇內(nèi)容介紹了“JavaScript如何調(diào)用棧”的有關(guān)知識(shí),在實(shí)際案例的操作過(guò)程中,不少人都會(huì)遇到這樣的困境,接下來(lái)就讓小編帶領(lǐng)大家學(xué)習(xí)一下如何處理這些情況吧!希望大家仔細(xì)閱讀,能夠?qū)W有所成!
成都網(wǎng)站建設(shè)哪家好,找創(chuàng)新互聯(lián)公司!專注于網(wǎng)頁(yè)設(shè)計(jì)、網(wǎng)站建設(shè)、微信開發(fā)、微信平臺(tái)小程序開發(fā)、集團(tuán)企業(yè)網(wǎng)站設(shè)計(jì)等服務(wù)項(xiàng)目。核心團(tuán)隊(duì)均擁有互聯(lián)網(wǎng)行業(yè)多年經(jīng)驗(yàn),服務(wù)眾多知名企業(yè)客戶;涵蓋的客戶類型包括:成都玻璃隔斷等眾多領(lǐng)域,積累了大量豐富的經(jīng)驗(yàn),同時(shí)也獲得了客戶的一致贊揚(yáng)!
1:基本概念
棧(stack):用來(lái)保存簡(jiǎn)單的數(shù)據(jù)字段。
堆(heap):用來(lái)保存棧中簡(jiǎn)單的數(shù)據(jù)字段對(duì)指針的引用。
隊(duì)列:是一種先進(jìn)先出的線性數(shù)據(jù)結(jié)構(gòu)。
函數(shù)的調(diào)用的進(jìn)棧和出棧的順序,遵循 先進(jìn)后出 的原則。
空間分配: 堆:一般由程序員釋放,如果程序員不釋放就會(huì)在結(jié)束時(shí)由OS回收;
棧:一般由操作系統(tǒng)自動(dòng)分配釋放。
緩存方式: 堆:存放在二級(jí)緩存中,生命周期一般是由虛擬機(jī)的垃圾回收算法決定的;
棧:存放在一級(jí)緩存中,被調(diào)用時(shí)處于存儲(chǔ)空間,調(diào)用完立即釋放。
操作數(shù)據(jù):堆棧(先進(jìn)后出),隊(duì)列(先進(jìn)先出)。
調(diào)用棧是一種棧結(jié)構(gòu),它用來(lái)存儲(chǔ)計(jì)算機(jī)程序執(zhí)行時(shí)候其活躍子程序的信息。它是一種LIFO的數(shù)據(jù)結(jié)構(gòu),將記錄代碼運(yùn)行時(shí)的執(zhí)行上下文。當(dāng)遇到某個(gè)函數(shù)的調(diào)用語(yǔ)句時(shí),它將會(huì)記錄當(dāng)前的執(zhí)行上下文,將函數(shù)入棧,并為其創(chuàng)建一個(gè)新的執(zhí)行上下文。(比如什么函數(shù)正在執(zhí)行,什么函數(shù)正在被這個(gè)函數(shù)調(diào)用等等信息)。
調(diào)用棧是解析器的一種機(jī)制。
javascript是一門單線程語(yǔ)言,主線程在同一時(shí)間只能處理一件事。那javascript是如何處理處理函數(shù)的調(diào)用關(guān)系的?
答案是——調(diào)用棧。
2:Event Loop(事件循環(huán))
JavaScript是一個(gè)單線程,它執(zhí)行的所有代碼都放在下面這個(gè)Call Stack里面,當(dāng)Call Stack執(zhí)行完畢之后,就會(huì)再右側(cè)的隊(duì)列里面找任務(wù),如果有微任務(wù),就會(huì)先執(zhí)行微任務(wù),再去執(zhí)行宏任務(wù)。
事件循環(huán):就是同步任務(wù)進(jìn)入主線程,異步任務(wù)加入到任務(wù)隊(duì)列中。等主線程的任務(wù)執(zhí)行完就去執(zhí)行任務(wù)隊(duì)列中的任務(wù),這個(gè)過(guò)程會(huì)不斷重復(fù)。所有同步任務(wù)都在主線程上執(zhí)行,形成一個(gè)執(zhí)行棧。主線程之外, 存在一個(gè)任務(wù)隊(duì)列(task queue), 異步任務(wù)有了運(yùn)行結(jié)果會(huì)在任務(wù)隊(duì)列之中放置一個(gè)任務(wù)。執(zhí)行棧中的所有同步任務(wù)執(zhí)行完畢后讀取任務(wù)隊(duì)列(先讀取微任務(wù)、宏任務(wù))不斷重復(fù)上面的第三步。
js既然是單線程那么肯定是排隊(duì)執(zhí)行代碼,怎么去排這個(gè)隊(duì)就是Event Loop,雖然js是單線程但是瀏覽器不是單線程。
console.log('script start'); setTimeout(function() { console.log('timeout1'); }, 10); new Promise(resolve => { console.log('promise1'); resolve(); setTimeout(() => console.log('timeout2'), 10); }).then(function() { console.log('then1') }) console.log('script end'); // * script start * promise1 * script end * then1 * timeout1 * timeout2
3:宏任務(wù)(Mask-task)
setTimeout
setInterval
I/O
特點(diǎn):由JavaScript線程外的宿主線程執(zhí)行,比如,定時(shí)器觸發(fā)線程setTimeout、setInterval,異步http請(qǐng)求線程。JavaScript線程不空閑宏任務(wù)永遠(yuǎn)沒有執(zhí)行機(jī)會(huì)。
for(let i=0; i<100000000; i++) {} setTimeout(function() { console.log('setTimeout1'); }, 1000); setTimeout(function() { console.log('setTimeout2'); }, 2000);
4:微任務(wù)(Mask-task)
promise
特點(diǎn):由JavaScript線程維護(hù),它的執(zhí)行時(shí)機(jī)是在主線程所有可執(zhí)行代碼執(zhí)行完成后執(zhí)行,瀏覽器渲染DOM前會(huì)全部執(zhí)行。
“JavaScript如何調(diào)用?!钡膬?nèi)容就介紹到這里了,感謝大家的閱讀。如果想了解更多行業(yè)相關(guān)的知識(shí)可以關(guān)注創(chuàng)新互聯(lián)網(wǎng)站,小編將為大家輸出更多高質(zhì)量的實(shí)用文章!