您好,登錄后才能下訂單哦!
這篇文章主要介紹“javascript兩個函數相互調用防止死循環的方法是什么”的相關知識,小編通過實際案例向大家展示操作過程,操作方法簡單快捷,實用性強,希望這篇“javascript兩個函數相互調用防止死循環的方法是什么”文章能幫助大家解決問題。
最近碰到了一個問題,就是兩個函數相互調用遭遇死循環的問題,想了半天終于想出了一個算法破解,姑且叫它熵遞減算法。
問題的抽象代碼如下
/* * methodA 和 methodB 循環調用,是死循環 * */ function methodA() { console.log('A的事情'); methodB(); } function methodB() { console.log('B的事情'); methodA(); }
不論調用哪個方法,都會產生死循環。
我想要的效果是:
如果觸發A方法時,也執行一下B方法,到此為止不再循環下去,反之亦然。
因此,必須能判斷方法是主動發起的,還是被動的。
抽象代碼如下:
/* * 解決問題的關鍵在于,判斷方法是主動發起的,還是被動的 * */ function methodA() { console.log('A的事情'); if('A是主動的'){ methodB(); }else{ // 不再調用下去 } } function methodB() { console.log('B的事情'); if('B是主動的'){ methodA(); }else{ // 不再調用下去 } }
解法,就是熵遞減算法,如下
/* * 熵遞減算法 * */ var pairMethodStep = 2; function methodA() { pairMethodStep --; console.log('A的事情'); if(pairMethodStep === 1){ methodB(); }else{ pairMethodStep = 2; } } function methodB() { pairMethodStep --; console.log('B的事情'); if(pairMethodStep === 1){ methodA(); }else{ pairMethodStep = 2; } }
熵遞減算法的說明:
給一個全局變量,叫做總步數pairMethodStep ,初始值為2。任一個方法執行時,做完自己的事情后,把pairMethodStep減成1。然后,判斷此時的pairMethodStep,如果是1, 就調用另一個方法;如果是0了,就不再繼續調用了,而是把pairMethodStep恢復成2。
我們分析一下代碼執行的過程。主動的方法執行前,pairMethodStep的值是2,它做完自己的事后,把pairMethodStep的值變成了1,緊跟著就會執行被動的方法;被動的方法執行前,pairMethodStep的值是1,被動的方法做完自己的事情后,把pairMethodStep的值減成了0,不會再調用另一個方法了(不會發生死循環了),而僅僅是把pairMethodStep還原成2。
目的達到。熵遞減算法,能完美地解決兩個函數相互調用的問題。
兩個函數互相調用時
(當一個系統比較大時,尤其是涉及到一些復雜的算法時,很有可能會碰到死循環的情況發生,造成系統的CPU飆升)
function a1() { console.log("a1"); b1(); } function b1() { console.log("b1"); a1(); }
會進入死循環
就類似for循環,或者遞歸函數如果沒有退出條件就會一直執行
let flagNum = 1; function a1() { flagNum--; console.log("a1"); if (flagNum === 0) { b1(); } else { flagNum = 1; } } function b1() { flagNum--; console.log("b1"); if (flagNum === 0) { a1(); } else { flagNum = 1; } }
關于“javascript兩個函數相互調用防止死循環的方法是什么”的內容就介紹到這里了,感謝大家的閱讀。如果想了解更多行業相關的知識,可以關注億速云行業資訊頻道,小編每天都會為大家更新不同的知識點。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。