首页 > nodejs,一个回调函数没有执行,大家帮忙看看是什么原因?

nodejs,一个回调函数没有执行,大家帮忙看看是什么原因?

项目地址 https://github.com/pana/nrm/blob/master/cli.js

我已经试图联系作者,可是我有点等不急,所以希望大家帮忙看看

当我执行nrm use *命令时,我发现在代码130行

setRegistry(r, function (err, result){});

他的回调函数并没有执行,也就是说 Registry has been set to ,r并没有打印出来

我在66行代码之后加入console.log(npm); 测试发现可以输出,而在130行之后的回调函数

console.log(npm); 却没有输出,因此猜测问题可能出现在130行代码


这个问题已经fix了, 现在改用npmconf 修改registry设置了


没有人回答吗?自己来回答好了。

我发现原因出现 setRegistry(r, function (err, result){}) 调用的run函数,其中run用到 child_process spawn,通过子进程执行命令行,问题出现ls.on('close', function(){});
在ubuntu linux 中 好像不会触发close,而将close改成exit后,问题得到解决。 子进程没有关闭,一系列原因导致 setRegistry(r, function (err, result){}) 的回调函数没有执行。

大概原因可能是这样了,但是我还想问问 子进程没有关闭,为什么会导致回调函数没有执行? 这其中的原因我还不是特别清楚。

【热门文章】
【热门文章】