眾所周知,非同步是得天獨厚的特點和優勢,但同時在程式中同步的需求(例如控製程式的執行順序為:func1 -> func2 ->func3 )也是很常見的。本文就是對這個問題記錄自己的一些想法。
需要執行的函數:
var func3 = function(req,res,callback){
setTimeout(function(){
console.log('in func3');
callback(req,res,3);
},1000);
}
可以看出在func1,func2和func3中都是用了setTimeout函數,執行的時間分別為13秒,5秒和1秒。由於nodejs異步的特性,如果使用普通的函數呼叫方法:
輸出內容:
原因是因為nodejs是異步的,func2不會等func1執行完畢後再執行,而是立即執行(func3也是如此)。由於func3的運行時間最短而率先結束,func2次之,func1最後。但這明顯不是我們想要的結果。怎麼辦?
解決方法一:callback
func1(req,res,function(){
func2(req,res,function(){
func3(req,res,function(){
process.exit(0);
})
});
});
這種方法雖然能快速的解決,但暴露的問題也很明顯,一是程式碼維護不方面,二是程式碼的深層嵌套看起來很不舒服。這種方法並不可取。
解決方法二:遞迴呼叫
//同步呼叫
var req = null;
var res = null;
var funcs = [func1,func2,func3];
var len = funcs.length;
executeFunc(funcs,0,len,req,res);
先將多個函數組成一個陣列。再可以利用遞歸函數的特性,使程式依照一定的順序執行。
解決方法三:呼叫類別庫
隨著nodejs的發展,回應的類別庫也越來越多。 Step和async 就是其中不錯的。
1.Step的調用相對較為清爽:
async.series(
[
function(callback){
func1(req,res,callback);
},
function(callback){
func2(req,res,callback);
},
function(callback){
func3(req,res,callback);
}
]
);