兩個函數(shù)相互調(diào)用如何防止死循環(huán)
兩個函數(shù)相互調(diào)用防止死循環(huán)
最近碰到了一個問題,就是兩個函數(shù)相互調(diào)用遭遇死循環(huán)的問題,想了半天終于想出了一個算法破解,姑且叫它熵遞減算法。
問題的抽象代碼如下
/*
* ?methodA 和 methodB 循環(huán)調(diào)用,是死循環(huán)
* */
function methodA() {
? ? console.log('A的事情');
? ? methodB();
}
function methodB() {
? ? console.log('B的事情');
? ? methodA();
}不論調(diào)用哪個方法,都會產(chǎn)生死循環(huán)。
我想要的效果是:
如果觸發(fā)A方法時,也執(zhí)行一下B方法,到此為止不再循環(huán)下去,反之亦然。
因此,必須能判斷方法是主動發(fā)起的,還是被動的。
抽象代碼如下:
/*
* ?解決問題的關(guān)鍵在于,判斷方法是主動發(fā)起的,還是被動的
* */
function methodA() {
? ? console.log('A的事情');
? ? if('A是主動的'){
? ? ? ? methodB();
? ? }else{
?? ??? ?// 不再調(diào)用下去
?? ?}
}
function methodB() {
? ? console.log('B的事情');
? ? if('B是主動的'){
? ? ? ? methodA();
? ? }else{
?? ??? ?// 不再調(diào)用下去
?? ?}
}解法,就是熵遞減算法,如下
/*
* 熵遞減算法
* */
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;
? ? }
}熵遞減算法的說明:
給一個全局變量,叫做總步數(shù)pairMethodStep ,初始值為2。任一個方法執(zhí)行時,做完自己的事情后,把pairMethodStep減成1。然后,判斷此時的pairMethodStep,如果是1, 就調(diào)用另一個方法;如果是0了,就不再繼續(xù)調(diào)用了,而是把pairMethodStep恢復(fù)成2。
我們分析一下代碼執(zhí)行的過程。主動的方法執(zhí)行前,pairMethodStep的值是2,它做完自己的事后,把pairMethodStep的值變成了1,緊跟著就會執(zhí)行被動的方法;被動的方法執(zhí)行前,pairMethodStep的值是1,被動的方法做完自己的事情后,把pairMethodStep的值減成了0,不會再調(diào)用另一個方法了(不會發(fā)生死循環(huán)了),而僅僅是把pairMethodStep還原成2。
目的達到。熵遞減算法,能完美地解決兩個函數(shù)相互調(diào)用的問題。
js函數(shù)互相調(diào)用碰到的問題
項目場景
兩個函數(shù)互相調(diào)用時
(當(dāng)一個系統(tǒng)比較大時,尤其是涉及到一些復(fù)雜的算法時,很有可能會碰到死循環(huán)的情況發(fā)生,造成系統(tǒng)的CPU飆升)
? ? ? ? function a1() {
? ? ? ? ? ? console.log("a1");
? ? ? ? ? ? b1();
? ? ? ? }
? ? ? ? function b1() {
? ? ? ? ? ? console.log("b1");
? ? ? ? ? ? a1();
? ? ? ? }問題描述
會進入死循環(huán)
原因分析
就類似for循環(huán),或者遞歸函數(shù)如果沒有退出條件就會一直執(zhí)行
解決方案
? ? ? ? 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;
? ? ? ? ? ? }
? ? ? ? }總結(jié)
以上為個人經(jīng)驗,希望能給大家一個參考,也希望大家多多支持腳本之家。
相關(guān)文章
微信小程序使用map組件實現(xiàn)獲取定位城市天氣或者指定城市天氣數(shù)據(jù)功能
這篇文章主要介紹了微信小程序使用map組件實現(xiàn)獲取定位城市天氣或者指定城市天氣數(shù)據(jù)功能,涉及微信小程序map組件結(jié)合微信API獲取天氣信息相關(guān)操作技巧,需要的朋友可以參考下2019-01-01
妙用Bootstrap的 popover插件實現(xiàn)校驗表單提示功能
最近使用bootstrap開發(fā)項目比較多,在表單校驗功能中用popover插件實現(xiàn)出錯提示功能很方面,下面小編給大家?guī)砹艘黄P(guān)于Bootstrap的 popover插件實現(xiàn)校驗表單提示功能的實現(xiàn)代碼,非常不錯,感興趣的朋友一起看看吧2016-08-08
Javascript實現(xiàn)Array和String互轉(zhuǎn)換的方法
這篇文章主要介紹了Javascript實現(xiàn)Array和String互轉(zhuǎn)換的方法,涉及JavaScript中toString方法與split方法的使用技巧,需要的朋友可以參考下2015-12-12
javascript 文章截取部分無損html顯示實現(xiàn)代碼
近在做一些內(nèi)容搜索的工作,搜索出來的內(nèi)容為html格式,列表部分需要顯示每項內(nèi)容的一部分。2010-05-05
js動態(tài)創(chuàng)建標(biāo)簽示例代碼
這篇文章主要以示例的方式為大家介紹下js如何動態(tài)創(chuàng)建標(biāo)簽,需要的朋友可以參考下2014-06-06

