有谁能简单地解释一下node.js的异步和回调函数

2013 年 6 月 2 日
 foru17
水平渣,看得我有点混了

大概就是
http.get(url,function(res){
在这里获得某个数据a
}

在外部调用数据a
console.log(a) //
8132 次点击
所在节点    Node.js
17 条回复
davepkxxx
2013 年 6 月 2 日
和js的异步和回调不一样?
Ricepig
2013 年 6 月 2 日
你就当它在某个时候(满足某个条件)就一定会调用就行,嘿嘿
xzl380
2013 年 6 月 2 日
“我不会等你,我先做我的,你继续做你的,等会我会向你要成果。”

这篇日记是不是有帮助呢?
http://www.ruanyifeng.com/blog/2012/12/asynchronous%EF%BC%BFjavascript.html
看里面解释的回调函数。

另外,看第一个例子就好了:
http://www.infoq.com/cn/news/2011/09/nodejs-async-code
fatpa
2013 年 6 月 2 日
当有异步通讯触发的时候就调用这个回调函数了,就像在C#里面是写一个委托去调用某个函数的,思路应该都差不多的
kfll
2013 年 6 月 2 日
在外部调用 console.log(a) 的话,这样:

setInterval( function() { console.log(a) }, 100 )

看日志你差不多就明白了
bigmusic
2013 年 6 月 2 日
axqd
2013 年 6 月 3 日
http.get(url,function(res){
在这里获得某个数据a
console.log(a)
}
zhujinliang
2013 年 6 月 3 日
回调函数而已。

function http_get_callback(res){
/// do something
}

http.get(url, http_get_callback);

这样写能看懂么

那么改成匿名函数再调一下位置呢

http.get(url, function(res){
/// do something
});
gdzdb
2013 年 6 月 3 日
就是字面上的意思。


比如正常的流程是
A→B→C
其中A→B需要5分钟才能执行完的话,那么执行C就是5分钟后的事情了。

而异步就是
A→C
→ B
在B出结果前,直接先执行C,不用等5分钟,但是这样子的话C的执行环境就跟B是没有关系了。



发现越简单的道理越难解释~
JeremyWei
2013 年 6 月 3 日
其实主要是event loop,看下这篇文章:
http://blog.mixu.net/2011/02/01/understanding-the-node-js-event-loop/
heroicYang
2013 年 6 月 3 日
简单回一个吧,回调函数就是你做完某事调我就行,这里面不一定涉及到异步。比如:
function a (callback) {
var now = new Date;
while (new Date - now <= 5000) {}
callback && callback();
}

a(function () { console.log('callback'); });

a();
console.log('callback');
并没有扯到所谓的异步。

function b (doSomething, doAnother) {
// 不好意思我要占用太久时间,doAnother你要等不及就先不管我吧
setTimeout(function () {
var now = new Date;
while (new Date - now <= 5000) {}
doSomething && doSomething();
}, 0);
doAnother && doAnother();
}
b(function () {
console.log('do something...');
}, function () {
console.log('do another...');
});
这里的doSomething和doAnother都是回调,但是它们在内部就是异步执行的了。。

异步编程主要就是解决等待问题...
heroicYang
2013 年 6 月 3 日
好吧代码格式乱完了,重新贴个截图吧。
chemzqm
2013 年 6 月 3 日
回调一般应该是在将来某个时候会执行,node里一般是触发IO事件的时候,这么做可以更有效利用系统调度,提高并发量。
foru17
2013 年 6 月 4 日
@heroicYang 多谢各位
hustlzp
2013 年 6 月 4 日
@heroicYang 这个字体是?感觉括号看起来蛮爽的~
heroicYang
2013 年 6 月 4 日
@hustlzp Monaco ~
judasnow
2013 年 7 月 4 日

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://v2ex.xtra.eu.org/t/70927

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX