怎么理解回調(diào)函數(shù)

這篇文章主要介紹“怎么理解回調(diào)函數(shù)”,在日常操作中,相信很多人在怎么理解回調(diào)函數(shù)問題上存在疑惑,小編查閱了各式資料,整理出簡(jiǎn)單好用的操作方法,希望對(duì)大家解答”怎么理解回調(diào)函數(shù)”的疑惑有所幫助!接下來,請(qǐng)跟著小編一起來學(xué)習(xí)吧!

成都創(chuàng)新互聯(lián)于2013年成立,是專業(yè)互聯(lián)網(wǎng)技術(shù)服務(wù)公司,擁有項(xiàng)目網(wǎng)站設(shè)計(jì)制作、成都做網(wǎng)站網(wǎng)站策劃,項(xiàng)目實(shí)施與項(xiàng)目整合能力。我們以讓每一個(gè)夢(mèng)想脫穎而出為使命,1280元微山做網(wǎng)站,已為上家服務(wù),為微山各地企業(yè)和個(gè)人服務(wù),聯(lián)系電話:18980820575

一切要從這樣的需求說起

假設(shè)你們公司要開發(fā)下一代國(guó)民App“明日油條”,一款主打解決國(guó)民早餐問題的App,為了加快開發(fā)進(jìn)度,這款應(yīng)用由A小組和B小組協(xié)同開發(fā)。

其中有一個(gè)核心模塊由A小組開發(fā)然后供B小組調(diào)用,這個(gè)核心模塊被封裝成了一個(gè)函數(shù),這個(gè)函數(shù)就叫make_youtiao()。

如果make_youtiao()這個(gè)函數(shù)執(zhí)行的很快并可以立即返回,那么B小組的同學(xué)只需要:

  1. 鴻蒙官方戰(zhàn)略合作共建——HarmonyOS技術(shù)社區(qū)

  2. 調(diào)用make_youtiao()

  3. 等待該函數(shù)執(zhí)行完成

  4. 該函數(shù)執(zhí)行完后繼續(xù)后續(xù)流程

從程序執(zhí)行的角度看這個(gè)過程是這樣的:

  1. 鴻蒙官方戰(zhàn)略合作共建——HarmonyOS技術(shù)社區(qū)

  2. 保存當(dāng)前被執(zhí)行函數(shù)的上下文

  3. 開始執(zhí)行make_youtiao()這個(gè)函數(shù)

  4. make_youtiao()執(zhí)行完后,控制轉(zhuǎn)回到調(diào)用函數(shù)中

怎么理解回調(diào)函數(shù)

如果世界上所有的函數(shù)都像make_youtiao()這么簡(jiǎn)單,那么程序員大概率就要失業(yè)了,還好程序的世界是復(fù)雜的,這樣程序員才有了存在的價(jià)值。

現(xiàn)實(shí)并不容易

現(xiàn)實(shí)中make_youtiao()這個(gè)函數(shù)需要處理的數(shù)據(jù)非常龐大,假設(shè)有10000個(gè),那么make_youtiao(10000)不會(huì)立刻返回,而是可能需要10分鐘才執(zhí)行完成并返回。

這時(shí)你該怎么辦呢?想一想這個(gè)問題。

可能有的同學(xué)會(huì)問,和剛才一樣直接調(diào)用不可以嗎,這樣多簡(jiǎn)單。

是的,這樣做沒有問題,但就像愛因斯坦說的那樣“一切都應(yīng)該盡可能簡(jiǎn)單,但是不能過于簡(jiǎn)單”。

想一想直接調(diào)用會(huì)有什么問題?

顯然直接調(diào)用的話,那么調(diào)用線程會(huì)被阻塞暫停,在等待10分鐘后才能繼續(xù)運(yùn)行。在這10分鐘內(nèi)該線程不會(huì)被操作系統(tǒng)分配CPU,也就是說該線程得不到任何推進(jìn)。

這并不是一種高效的做法。

沒有一個(gè)程序員想死盯著屏幕10分鐘后才能得到結(jié)果。

那么有沒有一種更加高效的做法呢?

想一想我們上一篇中那個(gè)一直盯著你寫代碼的老板(見《從小白到高手,你需要理解同步與異步》),我們已經(jīng)知道了這種一直等待直到另一個(gè)任務(wù)完成的模式叫做同步。

如果你是老板的話你會(huì)什么都不干一直盯著員工寫代碼嗎?因此一種更好的做法是程序員在代碼的時(shí)候老板該干啥干啥,程序員寫完后自然會(huì)通知老板,這樣老板和程序員都不需要相互等待,這種模式被稱為異步。

回到我們的主題,這里一種更好的方式是調(diào)用make_youtiao()這個(gè)函數(shù)后不再等待這個(gè)函數(shù)執(zhí)行完成,而是直接返回繼續(xù)后續(xù)流程,這樣A小組的程序就可以和make_youtiao()這個(gè)函數(shù)同時(shí)進(jìn)行了,就像這樣:

怎么理解回調(diào)函數(shù)

在這種情況下,回調(diào)(callback)就必須出場(chǎng)了。

為什么我們需要回調(diào)callback

有的同學(xué)可能還沒有明白為什么在這種情況下需要回調(diào),別著急,我們慢慢講。

假設(shè)我們“明日油條”App代碼第一版是這樣寫的:

make_youtiao(10000); sell();

可以看到這是最簡(jiǎn)單的寫法,意思很簡(jiǎn)單,制作好油條后賣出去。

怎么理解回調(diào)函數(shù)

我們已經(jīng)知道了由于make_youtiao(10000)這個(gè)函數(shù)10分鐘才能返回,你不想一直死盯著屏幕10分鐘等待結(jié)果,那么一種更好的方法是讓make_youtiao()這個(gè)函數(shù)知道制作完油條后該干什么,即,更好的調(diào)用make_youtiao的方式是這樣的:“制作10000個(gè)油條,炸好后賣出去”,因此調(diào)用make_youtiao就變出這樣了:

make_youtiao(10000, sell);

看到了吧,現(xiàn)在make_youtiao這個(gè)函數(shù)多了一個(gè)參數(shù),除了指定制作油條的數(shù)量外還可以指定制作好后該干什么,第二個(gè)被make_youtiao這個(gè)函數(shù)調(diào)用的函數(shù)就叫回調(diào),callback。

現(xiàn)在你應(yīng)該看出來了吧,雖然sell函數(shù)是你定義的,但是這個(gè)函數(shù)卻是被其它模塊調(diào)用執(zhí)行的,就像這樣:

怎么理解回調(diào)函數(shù)

make_youtiao這個(gè)函數(shù)是怎么實(shí)現(xiàn)的呢,很簡(jiǎn)單:

void make_youtiao(int num, func call_back) {     // 制作油條     call_back(); //執(zhí)行回調(diào)  }

這樣你就不用死盯著屏幕了,因?yàn)槟惆裮ake_youtiao這個(gè)函數(shù)執(zhí)行完后該做的任務(wù)交代給make_youtiao這個(gè)函數(shù)了,該函數(shù)制作完油條后知道該干些什么,這樣就解放了你的程序。

有的同學(xué)可能還是有疑問,為什么編寫make_youtiao這個(gè)小組不直接定義sell函數(shù)然后調(diào)用呢?

不要忘了明日油條這個(gè)App是由A小組和B小組同時(shí)開發(fā)的,A小組在編寫make_youtiao時(shí)怎么知道B小組要怎么用這個(gè)模塊,假設(shè)A小組真的自己定義sell函數(shù)就會(huì)這樣寫:

void make_youtiao(int num) {     real_make_youtiao(num);     sell(); //執(zhí)行回調(diào)  }

同時(shí)A小組設(shè)計(jì)的模塊非常好用,這時(shí)C小組也想用這個(gè)模塊,然而C小組的需求是制作完油條后放到倉(cāng)庫(kù)而不是不是直接賣掉,要滿足這一需求那么A小組該怎么寫呢?

void make_youtiao(int num) {     real_make_youtiao(num);          if (Team_B) {        sell(); // 執(zhí)行回調(diào)     } else if (Team_D) {        store(); // 放到倉(cāng)庫(kù)     } }

故事還沒完,假設(shè)這時(shí)D小組又想使用呢,難道還要接著添加if  else嗎?這樣的話A小組的同學(xué)只需要維護(hù)make_youtiao這個(gè)函數(shù)就能做到工作量飽滿了,顯然這是一種非常糟糕的設(shè)計(jì)。

所以你會(huì)看到,制作完油條后接下來該做什么不是實(shí)現(xiàn)make_youtiao的A小組該關(guān)心的事情,很明顯只有調(diào)用make_youtiao這個(gè)函數(shù)的使用方才知道。

因此make_youtiao的A小組完全可以通過回調(diào)函數(shù)將接下來該干什么交給調(diào)用方實(shí)現(xiàn),A小組的同學(xué)只需要針對(duì)回調(diào)函數(shù)這一抽象概念進(jìn)行編程就好了,這樣調(diào)用方在制作完油條后不管是賣掉、放到庫(kù)存還是自己吃掉等等想做什么都可以,A小組的make_youtiao函數(shù)根本不用做任何改動(dòng),因?yàn)锳小組是針對(duì)回調(diào)函數(shù)這一抽象概念來編程的。

以上就是回調(diào)函數(shù)的作用,當(dāng)然這也是針對(duì)抽象而不是具體實(shí)現(xiàn)進(jìn)行編程這一思想的威力所在。面向?qū)ο笾械亩鄳B(tài)本質(zhì)上就是讓你用來針對(duì)抽象而不是針對(duì)實(shí)現(xiàn)來編程的。

異步回調(diào)

故事到這里還沒有結(jié)束。

在上面的示例中,雖然我們使用了回調(diào)這一概念,也就是調(diào)用方實(shí)現(xiàn)回調(diào)函數(shù)然后再將該函數(shù)當(dāng)做參數(shù)傳遞給其它模塊調(diào)用。

但是,這里依然有一個(gè)問題,那就是make_youtiao函數(shù)的調(diào)用方式依然是同步的,關(guān)于同步異步請(qǐng),也就是說調(diào)用方是這樣實(shí)現(xiàn)的:

make_youtiao(10000, sell); // make_youtiao函數(shù)返回前什么都做不了

 怎么理解回調(diào)函數(shù)

我們可以看到,調(diào)用方必須等待make_youtiao函數(shù)返回后才可以繼續(xù)后續(xù)流程,我們?cè)賮砜聪耺ake_youtiao函數(shù)的實(shí)現(xiàn):

void make_youtiao(int num, func call_back) {     real_make_youtiao(num);     call_back(); //執(zhí)行回調(diào)  }

看到了吧,由于我們要制作10000個(gè)油條,make_youtiao函數(shù)執(zhí)行完需要10分鐘,也就是說即便我們使用了回調(diào),調(diào)用方完全不需要關(guān)心制作完油條后的后續(xù)流程,但是調(diào)用方依然會(huì)被阻塞10分鐘,這就是同步調(diào)用的問題所在。

如果你真的理解了上一節(jié)的話應(yīng)該能想到一種更好的方法了。

沒錯(cuò),那就是異步調(diào)用。

反正制作完油條后的后續(xù)流程并不是調(diào)用方該關(guān)心的,也就是說調(diào)用方并不關(guān)心make_youtiao這一函數(shù)的返回值,那么一種更好的方式是:把制作油條的這一任務(wù)放到另一個(gè)線程(進(jìn)程)、甚至另一臺(tái)機(jī)器上。

如果用線程實(shí)現(xiàn)的話,那么make_youtiao就是這樣實(shí)現(xiàn)了:

void make_youtiao(int num, func call_back) {     // 在新的線程中執(zhí)行處理邏輯     create_thread(real_make_youtiao,                   num,                   call_back); }

 怎么理解回調(diào)函數(shù)

看到了吧,這時(shí)當(dāng)我們調(diào)用make_youtiao時(shí)就會(huì)立刻返回,即使油條還沒有真正開始制作,而調(diào)用方也完全無需等待制作油條的過程,可以立刻執(zhí)行后流程:

make_youtiao(10000, sell); // 立刻返回 // 執(zhí)行后續(xù)流程

這時(shí)調(diào)用方的后續(xù)流程可以和制作油條同時(shí)進(jìn)行,這就是函數(shù)的異步調(diào)用,當(dāng)然這也是異步的高效之處。

新的編程思維模式

讓我們?cè)賮碜屑?xì)的看一下這個(gè)過程。

程序員最熟悉的思維模式是這樣的:

  • 調(diào)用某個(gè)函數(shù),獲取結(jié)果

  • 處理獲取到的結(jié)果

res = request(); handle(res);

這就是函數(shù)的同步調(diào)用,只有request()函數(shù)返回拿到結(jié)果后,才能調(diào)用handle函數(shù)進(jìn)行處理,request函數(shù)返回前我們必須等待,這就是同步調(diào)用,其控制流是這樣的:

怎么理解回調(diào)函數(shù)

但是如果我們想更加高效的話,那么就需要異步調(diào)用了,我們不去直接調(diào)用handle函數(shù),而是作為參數(shù)傳遞給request:

request(handle);

我們根本就不關(guān)心request什么時(shí)候真正的獲取的結(jié)果,這是request該關(guān)心的事情,我們只需要把獲取到結(jié)果后該怎么處理告訴request就可以了,因此request函數(shù)可以立刻返回,真的獲取結(jié)果的處理可能是在另一個(gè)線程、進(jìn)程、甚至另一臺(tái)機(jī)器上完成。

這就是異步調(diào)用,其控制流是這樣的:

怎么理解回調(diào)函數(shù)

從編程思維上看,異步調(diào)用和同步有很大的差別,如果我們把處理流程當(dāng)做一個(gè)任務(wù)來的話,那么同步下整個(gè)任務(wù)都是我們來實(shí)現(xiàn)的,但是異步情況下任務(wù)的處理流程被分為了兩部分:

  1. 鴻蒙官方戰(zhàn)略合作共建——HarmonyOS技術(shù)社區(qū)

  2. 第一部分是我們來處理的,也就是調(diào)用request之前的部分

  3. 第二部分不是我們處理的,而是在其它線程、進(jìn)程、甚至另一個(gè)機(jī)器上處理的。

我們可以看到由于任務(wù)被分成了兩部分,第二部分的調(diào)用不在我們的掌控范圍內(nèi),同時(shí)只有調(diào)用方才知道該做什么,因此在這種情況下回調(diào)函數(shù)就是一種必要的機(jī)制了。

也就是說回調(diào)函數(shù)的本質(zhì)就是“只有我們才知道做些什么,但是我們并不清楚什么時(shí)候去做這些,只有其它模塊才知道,因此我們必須把我們知道的封裝成回調(diào)函數(shù)告訴其它模塊”。

現(xiàn)在你應(yīng)該能看出異步回調(diào)這種編程思維模式和同步的差異了吧。

接下來我們給回調(diào)一個(gè)較為學(xué)術(shù)的定義

正式定義

在計(jì)算機(jī)科學(xué)中,回調(diào)函數(shù)是指一段以參數(shù)的形式傳遞給其它代碼的可執(zhí)行代碼。

這就是回調(diào)函數(shù)的定義了。

回調(diào)函數(shù)就是一個(gè)函數(shù),和其它函數(shù)沒有任何區(qū)別。

注意,回調(diào)函數(shù)是一種軟件設(shè)計(jì)上的概念,和某個(gè)編程語(yǔ)言沒有關(guān)系,幾乎所有的編程語(yǔ)言都能實(shí)現(xiàn)回調(diào)函數(shù)。

對(duì)于一般的函數(shù)來說,我們自己編寫的函數(shù)會(huì)在自己的程序內(nèi)部調(diào)用,也就是說函數(shù)的編寫方是我們自己,調(diào)用方也是我們自己。

但回調(diào)函數(shù)不是這樣的,雖然函數(shù)編寫方是我們自己,但是函數(shù)調(diào)用方不是我們,而是我們引用的其它模塊,也就是第三方庫(kù),我們調(diào)用第三方庫(kù)中的函數(shù),并把回調(diào)函數(shù)傳遞給第三方庫(kù),第三方庫(kù)中的函數(shù)調(diào)用我們編寫的回調(diào)函數(shù),如圖所示:

怎么理解回調(diào)函數(shù)

而之所以需要給第三方庫(kù)指定回調(diào)函數(shù),是因?yàn)榈谌綆?kù)的編寫者并不清楚在某些特定節(jié)點(diǎn),比如我們舉的例子油條制作完成、接收到網(wǎng)絡(luò)數(shù)據(jù)、文件讀取完成等之后該做什么,這些只有庫(kù)的使用方才知道,因此第三方庫(kù)的編寫者無法針對(duì)具體的實(shí)現(xiàn)來寫代碼,而只能對(duì)外提供一個(gè)回調(diào)函數(shù),庫(kù)的使用方來實(shí)現(xiàn)該函數(shù),第三方庫(kù)在特定的節(jié)點(diǎn)調(diào)用該回調(diào)函數(shù)就可以了。

另一點(diǎn)值得注意的是,從圖中我們可以看出回調(diào)函數(shù)和我們的主程序位于同一層中,我們只負(fù)責(zé)編寫該回調(diào)函數(shù),但并不是我們來調(diào)用的。

最后值得注意的一點(diǎn)就是回調(diào)函數(shù)被調(diào)用的時(shí)間節(jié)點(diǎn),回調(diào)函數(shù)只在某些特定的節(jié)點(diǎn)被調(diào)用,就像上面說的油條制作完成、接收到網(wǎng)絡(luò)數(shù)據(jù)、文件讀取完成等,這些都是事件,也就是event,本質(zhì)上我們編寫的回調(diào)函數(shù)就是用來處理event的,因此從這個(gè)角度看回調(diào)函數(shù)不過就是event  handler,因此回調(diào)函數(shù)天然適用于事件驅(qū)動(dòng)編程event-driven,我們將會(huì)在后續(xù)文章中再次回到這一主題。

回調(diào)的類型

我們已經(jīng)知道有兩種類型的回調(diào),這兩種類型的回調(diào)區(qū)別在于回調(diào)函數(shù)被調(diào)用的時(shí)機(jī)。

注意,接下來會(huì)用到同步和異步的概念,對(duì)這兩個(gè)概念不熟悉的同學(xué)可以參考上一盤文章《從小白到高手,你需要理解同步和異步》。

同步回調(diào)

這種回調(diào)就是通常所說的同步回調(diào)synchronous callbacks、也有的將其稱為阻塞式回調(diào)blocking  callbacks,或者什么修飾都沒有,就是回調(diào),callback,這是我們最為熟悉的回調(diào)方式。

當(dāng)我們調(diào)用某個(gè)函數(shù)A并以參數(shù)的形式傳入回調(diào)函數(shù)后,在A返回之前回調(diào)函數(shù)會(huì)被執(zhí)行,也就是說我們的主程序會(huì)等待回調(diào)函數(shù)執(zhí)行完成,這就是所謂的同步回調(diào)。

怎么理解回調(diào)函數(shù)

有同步回調(diào)就有異步回調(diào)。

異步回調(diào)

不同于同步回調(diào),  當(dāng)我們調(diào)用某個(gè)函數(shù)A并以參數(shù)的形式傳入回調(diào)函數(shù)后,A函數(shù)會(huì)立刻返回,也就是說函數(shù)A并不會(huì)阻塞我們的主程序,一段時(shí)間后回調(diào)函數(shù)開始被執(zhí)行,此時(shí)我們的主程序可能在忙其它任務(wù),回調(diào)函數(shù)的執(zhí)行和我們主程序的運(yùn)行同時(shí)進(jìn)行。

既然我們的主程序和回調(diào)函數(shù)的執(zhí)行可以同時(shí)發(fā)生,因此一般情況下,主程序和回調(diào)函數(shù)的執(zhí)行位于不同的線程或者進(jìn)程中。

怎么理解回調(diào)函數(shù)

這就是所謂的異步回調(diào),asynchronous callbacks,也有的資料將其稱為deferred callbacks  ,名字很形象,延遲回調(diào)。

從上面這兩張圖中我們也可以看到,異步回調(diào)要比同步回調(diào)更能充分的利用機(jī)器資源,原因就在于在同步模式下主程序會(huì)“偷懶”,因?yàn)檎{(diào)用其它函數(shù)被阻塞而暫停運(yùn)行,但是異步調(diào)用不存在這個(gè)問題,主程序會(huì)一直運(yùn)行下去。

因此,異步回調(diào)更常見于I/O操作,天然適用于Web服務(wù)這種高并發(fā)場(chǎng)景。

回調(diào)對(duì)應(yīng)的編程思維模式

讓我們用簡(jiǎn)單的幾句話來總結(jié)一下回調(diào)下與常規(guī)編程思維模式的不同。假設(shè)我們想處理某項(xiàng)任務(wù),這項(xiàng)任務(wù)需要依賴某項(xiàng)服務(wù)S,我們可以將任務(wù)的處理分為兩部分,調(diào)用服務(wù)S前的部分PA,和調(diào)用服務(wù)S后的部分PB。在常規(guī)模式下,PA和PB都是服務(wù)調(diào)用方來執(zhí)行的,也就是我們自己來執(zhí)行PA部分,等待服務(wù)S返回后再執(zhí)行PB部分。但在回調(diào)這種方式下就不一樣了。在這種情況下,我們自己來執(zhí)行PA部分,然后告訴服務(wù)S:“等你完成服務(wù)后執(zhí)行PB部分”。因此我們可以看到,現(xiàn)在一項(xiàng)任務(wù)是由不同的模塊來協(xié)作完成的。即:常規(guī)模式:調(diào)用完S服務(wù)后后我去執(zhí)行X任務(wù),回調(diào)模式:調(diào)用完S服務(wù)后你接著再去執(zhí)行X任務(wù),其中X是服務(wù)調(diào)用方制定的,區(qū)別在于誰來執(zhí)行。

為什么異步回調(diào)越來越重要

在同步模式下,服務(wù)調(diào)用方會(huì)因服務(wù)執(zhí)行而被阻塞暫停執(zhí)行,這會(huì)導(dǎo)致整個(gè)線程被阻塞,因此這種編程方式天然不適用于高并發(fā)動(dòng)輒幾萬幾十萬的并發(fā)連接場(chǎng)景,針對(duì)高并發(fā)這一場(chǎng)景,異步其實(shí)是更加高效的,原因很簡(jiǎn)單,你不需要在原地等待,因此從而更好的利用機(jī)器資源,而回調(diào)函數(shù)又是異步下不可或缺的一種機(jī)制。

回調(diào)地獄,callback hell

有的同學(xué)可能認(rèn)為有了異步回調(diào)這種機(jī)制應(yīng)付起一切高并發(fā)場(chǎng)景就可以高枕無憂了。實(shí)際上在計(jì)算機(jī)科學(xué)中還沒有任何一種可以橫掃一切包治百病的技術(shù),現(xiàn)在沒有,在可預(yù)見的將來也不會(huì)有,一切都是妥協(xié)的結(jié)果。那么異步回調(diào)這種機(jī)制有什么問題呢?實(shí)際上我們已經(jīng)看到了,異步回調(diào)這種機(jī)制和程序員最熟悉的同步模式不一樣,在可理解性上比不過同步,而如果業(yè)務(wù)邏輯相對(duì)復(fù)雜,比如我們處理某項(xiàng)任務(wù)時(shí)不止需要調(diào)用一項(xiàng)服務(wù),而是幾項(xiàng)甚至十幾項(xiàng),如果這些服務(wù)調(diào)用都采用異步回調(diào)的方式來處理的話,那么很有可能我們就陷入回調(diào)地獄中。舉個(gè)例子,假設(shè)處理某項(xiàng)任務(wù)我們需要調(diào)用四個(gè)服務(wù),每一個(gè)服務(wù)都需要依賴上一個(gè)服務(wù)的結(jié)果,如果用同步方式來實(shí)現(xiàn)的話可能是這樣的:a  = GetServiceA();

b = GetServiceB(a);  c = GetServiceC(b);  d = GetServiceD(c);

代碼很清晰,很容易理解有沒有。我們知道異步回調(diào)的方式會(huì)更加高效,那么使用異步回調(diào)的方式來寫將會(huì)是什么樣的呢?GetServiceA(function(a){

GetServiceB(a, function(b){  GetServiceC(b, function(c){  GetServiceD(c, function(d) {  ....  });  });  });

我想不需要再?gòu)?qiáng)調(diào)什么了吧,你覺得這兩種寫法哪個(gè)更容易理解,代碼更容易維護(hù)呢?博主有幸曾經(jīng)維護(hù)過這種類型的代碼,不得不說每次增加新功能的時(shí)候恨不得自己化為兩個(gè)分身,一個(gè)不得不去重讀一邊代碼;另一個(gè)在一旁罵自己為什么當(dāng)初選擇維護(hù)這個(gè)項(xiàng)目。異步回調(diào)代碼稍不留意就會(huì)跌到回調(diào)陷阱中,那么有沒有一種更好的辦法既能結(jié)合異步回調(diào)的高效又能結(jié)合同步編碼的簡(jiǎn)單易讀呢?幸運(yùn)的是,答案是肯定的,我們會(huì)在后續(xù)文章中詳細(xì)講解這一技術(shù)。

到此,關(guān)于“怎么理解回調(diào)函數(shù)”的學(xué)習(xí)就結(jié)束了,希望能夠解決大家的疑惑。理論與實(shí)踐的搭配能更好的幫助大家學(xué)習(xí),快去試試吧!若想繼續(xù)學(xué)習(xí)更多相關(guān)知識(shí),請(qǐng)繼續(xù)關(guān)注創(chuàng)新互聯(lián)網(wǎng)站,小編會(huì)繼續(xù)努力為大家?guī)砀鄬?shí)用的文章!

分享標(biāo)題:怎么理解回調(diào)函數(shù)
路徑分享:http://muchs.cn/article6/gppoig.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供移動(dòng)網(wǎng)站建設(shè)、App開發(fā)動(dòng)態(tài)網(wǎng)站、電子商務(wù)外貿(mào)建站、標(biāo)簽優(yōu)化

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來源: 創(chuàng)新互聯(lián)

h5響應(yīng)式網(wǎng)站建設(shè)