0

我尝试重新连接我的大脑以进行异步编码,但我仍然似乎仍然失败。不幸的是,在这种情况下,我无法弄清楚如何正确地做到这一点。让我举个例子吧:

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

谢谢

4

1 回答 1

2

好像你忘了nummessages在你的递归调用中传递:

decodemessage(i+1, nummessages);

这就是为什么我个人在使用递归时大多向后循环(到零)。

于 2012-11-07T11:26:36.317 回答