1. 程式人生 > >nodeJS實現方法的同步效果(去非同步)

nodeJS實現方法的同步效果(去非同步)

前言:
nodeJS最大的特點就是其非同步操作,其後邊方法的執行不會等到前邊方法執行完才去執行,而是同時執行好幾個方法,這種方式在給我們提高效率的同時也給開發多多少少帶來了不便,有時候我們不要求有這種效果的出現,這時候就需要進行去非同步操作。
node的去非同步方式主要有三種:方法巢狀,遞迴呼叫,呼叫類庫

【例項程式碼】

var func1 = function(req,res,callback){

    setTimeout(function(){
        console.log('執行 func1');
        callback(req,res,1);
    },13000);
}

var func2 = function(req,res,callback){
    setTimeout(function(){
        console.log('執行 func2');
        callback(req,res,2);
    },5000);
}

var func3 = function(req,res,callback){
    setTimeout(function(){
        console.log('執行 func3');
        callback(req,res,3);
    },1000);
}

#可以看出在func1,func2和func3中都是用了setTimeout函式,執行的時間分別為13秒,5秒和1秒。由於nodejs非同步的特性,如果使用普通的函式呼叫方法:

var req = null;
var res = null;
var callback = function(){};
func1(req,res,callback);
func2(req,res,callback);
func3(req,res,callback);

#列印結果(非同步結果)
執行 func3
執行 func2
執行 func1

#原因是因為nodejs是非同步的,func2不會等func1執行完畢後再執行,而是立即執行(func3也是如此)。由於func3的執行時間最短而率先結束,func2次之,func1最後。但這明顯不是我們想要的結果。怎麼辦?

【處理去除非同步效果】

                (1):方法巢狀
var req = null;
var res = null;
func1(req,res,function(){
    func2(req,res,function(){
        func3(req,res,function(){
            process.exit(0);
        })
    });
});
#這種方法雖然能快速的解決,但暴露的問題也很明顯,一是程式碼維護不方面,二是程式碼的深層巢狀看起來很不舒服。這種方法並不可取。
                (2):遞迴呼叫
function executeFunc(funcs,count,sum,req,res){
    if(count == sum){
        return ;
    }else{
        funcs[count](req,req,function(){
            count++;
            executeFunc(funcs,count,sum,req,res);
        });
    }
} 
//同步呼叫
var req = null;
var res = null;
var funcs = [func1,func2,func3];
var len = funcs.length;
executeFunc(funcs,0,len,req,res);
#先將多個函式組成一個數組。再可以利用遞迴函式的特性,使程式按照一定的順序執行。
                (3):呼叫類庫 Step和async
#隨著nodejs的發展,響應的類庫也越來越多。Step和async 就是其中不錯的。
# 方式一: Step實現  即用step方法將要實現同步的方法包裹起來

Step(
    function thefunc1(){
        console.log(finishFlag);
        func1(this);
    },

    function thefunc2(finishFlag){
        console.log(finishFlag);
        func2(this);
    },

    function thefunc3(finishFlag){
        console.log(finishFlag);
        func3(this);
    }
);

# 方式二:async實現  其本質是使用async 的 series方法實現

var req = null;
var res = null;
var callback = function(){};
async.series(
    [
        function(callback){
            func1(req,res,callback);
        },

        function(callback){
            func2(req,res,callback);
        },

       function(callback){
            func3(req,res,callback);
        }
    ]
);