js同步程序是如何向異步程序演變的
use(bufRcv, closure.a, closure.b);
return 0;
}
// 為了統(tǒng)一回調(diào)函數(shù)的形式并且縮短回調(diào)的參數(shù)列表,將這種需要透傳的參數(shù)只有一個(gè)
// 統(tǒng)一的數(shù)據(jù)結(jié)構(gòu)打包
void get_data_v6(int a, int b)
{
char bufCmd[]="cmd=1001&uin=123456¶m=abc";
char bufRcv[4096];
send_and_recv(addr, bufCmd, bufRcv, callback); } // end of get_data_v6
// definition of call back function
int callback(char* bufRcv, struct closure) {
use(bufRcv, closure.a, closure.b);
return 0;
}
7 JS的異步調(diào)用
view plaincopy to clipboardprint?
//
// 寫成JS代碼就變成現(xiàn)在這個(gè)樣子
// url對(duì)應(yīng)之前的addr
// 使用匿名函數(shù)代替原來命名的callback定義
// 原生支持閉包c(diǎn)losure
//
function get_data_js(a, b)
{
var bufCmd = "cmd=1001&uin=123456¶m=abc";
var bufRcv;
send_and_recv_with_xhr(/*addr*/url, bufCmd, bufRcv, /*callback/* //); } // end of get_data_js
function(bufRcv/*, closure*/) {
use(bufRcv, /*closure.*/a, /*closure.*/b);
return 0;
}
);
}
//
// 寫成JS代碼就變成現(xiàn)在這個(gè)樣子
// url對(duì)應(yīng)之前的addr
// 使用匿名函數(shù)代替原來命名的callback定義
// 原生支持閉包c(diǎn)losure
//
function get_data_js(a, b)
{
var bufCmd = "cmd=1001&uin=123456¶m=abc";
var bufRcv;
send_and_recv_with_xhr(/*addr*/url, bufCmd, bufRcv, /*callback/* //); } // end of get_data_js
function(bufRcv/*, closure*/) {
use(bufRcv, /*closure.*/a, /*closure.*/b);
return 0;
}
);
}
總結(jié)
1 JS的異步調(diào)用的編寫,其實(shí)和同步編寫的過程是一樣的。只不過是因?yàn)楫惒秸{(diào)用的時(shí)候并不阻塞等待一個(gè)網(wǎng)絡(luò)調(diào)用的完成或者事件的發(fā)生,所以將原來完整的過程分成了兩個(gè)割裂的兩塊。
2 分割成兩塊以后,本來也沒什么問題,不過就是存在后半段處理的過程需要依賴前半段的中間結(jié)果或者參數(shù),這些參數(shù)很可能是外部傳入的。所以為了讓這個(gè)中間參數(shù)的傳遞變得方便一些,不用為了同樣的事情編寫代碼,于是引入了閉包。最終,閉包的作用是使得代碼的后半段和前半段的運(yùn)行環(huán)境完全一致,以使得這種參數(shù)傳遞透明化。由于,當(dāng)前的流程本來就可能是更大的流程的后半段,所以使得閉包具有了可傳遞性,也就是閉包變成了閉包鏈。
所以,最終將異步調(diào)用看成是同步調(diào)用的上下兩段即可,之前設(shè)計(jì)優(yōu)美的同步程序的各種方法和經(jīng)驗(yàn)都可以用于異步調(diào)用中。