nodejs實現函數串行執行
眾所周知,nodejs是用非阻塞異步io機制,也就是說函數執行完成的先后順序和代碼的編寫的先后順序可能不同,實際的順序取決于一個函數自身執行的快慢。這就出現一個在nodejs中怎么編寫串行執行也就是順序執行代碼的問題。試想,要是你寫了2個函數,一個查詢數據庫,另一個返回查詢的結果,要是不用串行執行那么還沒等數據庫查詢完畢就返回了結果,這顯然是不行的。因而串行執行在nodejs中很有用。那么怎么實現呢?
大家可能會說,將返回查詢結果的函數寫在查詢數據庫函數的回調函數里面就好了呀,但是有過開發經驗的朋友一定知道,要是情況比較復雜時就會產生一個回調地獄的問題,即層層嵌套,最后都不知道自己寫了些什么,可讀性和維護性很差。
我們不防換個思路,要是將這些想要順序執行的函數放到一個數組里面,當一個函數執行完畢時在執行數組里面的下一個函數不就行了嘛。其實,nodejs開源社區中的很多串行模塊的基本思想就是這個。接下來我們一步一步完成這個串行的demo:
1.首先我們定義一個保存函數執行順序的數值:
var tasks = [];
2.再定義一個往數值里面加入串行化執行函數的函數:
function addTask(task){ tasks.push(task);}
3.執行數組中下一個函數的函數:
function next(){ if(tasks.length > 0){ tasks.shift()(); }else{ return; }}
ok,大功告成,接下來定義幾個測試函數:
var task1 = function(){ console.log('task1 is finished'); next();}var task2 = function(){ console.log('task2 is finished'); next();}var task3 = function(){ console.log('task3 is finished'); next();}
開始測試:
addTask(task1);addTask(task2);addTask(task3);next()
換個順序:
addTask(task1);addTask(task3);addTask(task2);next();
ok,大功告成?;谶@個思想,在實際開發中大家可以定義一個模塊,將這個串行打包,再也不用害怕回調地獄問題啦。
還可以用第三方庫,如async.
總結
以上就是這篇文章的全部內容了,希望本文的內容對大家的學習或者工作具有一定的參考學習價值,謝謝大家對VeVb武林網的支持。
新聞熱點
疑難解答