我尝试重新连接我的大脑以进行异步编码,但我仍然似乎仍然失败。不幸的是,在这种情况下,我无法弄清楚如何正确地做到这一点。让我举个例子吧:
var nconf = require('nconf');
nconf.argv()
.env();
function runme(callback){
var nummessages = nconf.get('SMS_MESSAGES');
decodemessage(0, nummessages);
callback();
}
function decodemessage(i, nummessages) {
if( i < nummessages ) {
var message = 'SMS_'+(i+1)+'_TEXT';
var number = 'SMS_'+(i+1)+'_NUMBER';
console.log('number: '+number);
console.log('message: '+message);
console.log('message text: '+ nconf.get(message));
console.log('message number: '+ nconf.get(number));
decodemessage(i+1);
}
}
runme(function(){
process.exit(0);
});
这由 gammu-smsd 调用,它接收 SMS 消息并将它们放入 ENV vars 并启动脚本。只要我自己运行它就可以正常工作,返回代码似乎也可以。当我从 gammu-smsd 运行它时,它失败了,看起来 decodemessage 从未执行过。一些调试输出显示我确实进入了 runme()。
我的猜测是 runme() 中的回调在递归 decodemessage() 调用完成之前执行。我是对的,如果是这样,有人可以解释我如何正确地做到这一点吗?
如果你想像这样测试运行它:
node server.js --SMS_MESSAGES 2 --SMS_1_TEXT blabliblo --SMS_1_NUMBER=47796546546 --SMS_2_TEXT Iammessagetwo --SMS_2_NUMBER 12345678
谢谢