javascript Deferred和遞迴次數限制執行個體,javascriptdeferred
你知道Deferred和遞迴次數限制嗎?下面有個不錯的執行個體,大家可以看看
function runAsyncTTS(text,speecher,audiopath) { var def = jQuery.Deferred(); var args = {"SynthText": text, "VoiceSpeecher": speecher, "WordSpeed": "3", "UseCSSML": "0", "AudioPath": audiopath}; tts.asyncTTS(JSON.stringify(args),function(err,result) { def.resolve(result); }); return def.promise(); }
function textToSpeechBat(metaJson, speecher, audioPath) { var def = $.Deferred(); var result = {originalWords:"", resultJsonArr:[]}; var jsons=""; for(var index=0;index < metaJson.words.length;index++) { var audioName = metaJson.words[index]['audio']; audioName = audioName.replace('.mp3',''); var audioFile = audioPath +"/" + audioName + '.wav'; var args = '{"SynthText": "'+metaJson.words[index]['word']+'", "VoiceSpeecher": "'+speecher+'", "WordSpeed": "3", "UseCSSML": "0", "AudioPath": "'+audioFile+'"}'; jsons += args + "|"; } jsons = jsons.substr(0,jsons.length-1); tts.asyncTTSBat(jsons,function(err,ret) { result['resultJsonArr'] = ret.split('|'); def.resolve(result); }); return def.promise(); }
function textToSpeechWithTryTimes(metaJson, speecher, audioPath,times) { var def = $.Deferred(); var ttsRet = null; var ttsCallBack = function(index) { if(index < times) { textToSpeechBat(metaJson,speecher,audioPath).done(function (ret) { console.log("textToSpeechWithTryTimes:"+JSON.stringify(ret)); ttsRet = ret; var resultJsonArr = ret.resultJsonArr; var audioFlag = true; for(var i=0;i<resultJsonArr.length;i++) { if(resultJsonArr[i] == "") { audioFlag = false; break; } var retObj = JSON.parse(resultJsonArr[i]); console.log(retObj['audioFlag']); if(retObj['audioFlag'] == 'false' || retObj['result']=="") { audioFlag = false; break; } } console.log(audioFlag); if(audioFlag == false) { console.log("textToSpeechWithTryTimes Fail, try again!"); ttsCallBack(++index); }else { console.log("textToSpeechWithTryTimes succeed,return"); def.resolve(ret); } }); } if(index == times) { console.log("textToSpeechWithTryTimes timesover,return"); def.resolve(ttsRet); } }; ttsCallBack(0); return def.promise(); }
javascript遞迴函式
因為遞迴是一層層請求下去,而資料是一層層返回上來:
第一百次:1
第九十九:2+1(第一百次返回的資料)
第九十八:3+(2+1)(第九十九次返回的資料)
。。。
第一次:100+4950(第二次返回的資料)
為什麼TRUE可以呢?
因為true會被隱性轉換為1,而false會被隱性轉換為0。
遞迴就相當於調用了100次那個sum函數,這是很耗記憶體資源的;
一般可以用迴圈體實現的就盡量用迴圈體來實現,如上題目就可以改為下面的方式實現:
function sum(n){
var total = 0;
do{
total+=n;
}while(n--)
return total;
}
javascript遞迴問題
chrome已提示Maximum call stack size exceeded。