私は、非同期プログラミングとプロミスの使用について頭を悩ませようとしてきました。それらを理解するのを助けるために、いくつかの簡単なネストされたコードを書きましたが、問題が発生しました。
コードは次のとおりです: http://pastebin.com/hBtk9vER ライブラリのインストール時に必ずインストールしてください (npm install)
var when = require('when');
function promise() {
console.log("Promise");
promiseRead().then(function(string) {
console.log("Inner promise");
console.log(string);
});
}
function promiseRead() {
console.log("PromiseRead");
return baz().then(function() {
console.log("Inner Read");
var deferred = when.defer();
setTimeout(function() {
deferred.resolve("Hello World");
}, 5000);
});
}
function baz() {
console.log("BAZ");
return when(true);
}
promise();
私の問題は、解決後console.log(string)
にあると予想していたときに未定義であることです。興味深いことに、タイムアウトを削除すると、期待どおりに機能します。タイムアウトが終了する前に関数がコードを実行している理由を説明できる人はいますか。"Hello World"
promiseRead()
promise
promiseRead()
とても有難い