前言
众所周知,异步是得天独厚的特点和优势,但同时在程序中同步的需求(比如控制程序的执行顺序为:func1 -> func2 ->func3 )也是很常见的。
下面这篇文章主要介绍了关于NodeJS实现同步的相关内容,NodeJS被打上了单线程、非阻塞、事件驱动…..等标签。 在单线程的情况下,是无法开启子线程的。经过了很久的研究,发现并没有thread函数!!!但是有时候,我们确实需要“多线程”处理事务。nodeJS有两个很基础的api:setTimeout和setInterval。这两个函数都能实现“异步”。 nodeJS的异步实现:nodeJS有一个任务队列,在使用setInterval函数的时候,会每隔特定的时间向该任务队列增加任务,从而实现“多任务”处理。但是,“特定的时间”不代表是具体的时间,也有可能是会大于我们设定的时间,也有可能小于。
我们跑跑下面代码块
setInterval(function() {
console.log(new Date().getTime());
}, 1000);输出的结果如下:
1490531390640
1490531391654
1490531392660
1490531393665
1490531394670
1490531395670
1490531396672
1490531397675
……
我们可以看到,所有的时间间隔都是不一样的。时间的偏移不仅包含了间隔的1s,还包含了
console.log()的耗时,以及new Date()的耗时。在大量的数据统计下,时间间隔近似于1s。问题来了,setInterval是能实现多任务的效果,但是怎样才能实现任务之间的同步操作呢?
这里实现的方法是通过回调函数实现的。
function a(callback) {
// 模拟任务a耗时
setTimeout(function() {
console.log("task a end!");
// 回调任务b
callback();
}, 3000);
};function b() {
setTimeout(function() {
console.log("task b end!");
}, 5000);
}
a(b);
这里举了一个很简单的例子,就是将b方法的实现赋值给a方法的callback函数从而实现函数回调,但是会有个问题。假设a方法依赖于b方法,b方法依赖于c方法,c方法依赖于d方法…..也就意味着每个方法的实现都需要持有上一个方法的实例,从而实现回调。
function a(b, c, d) {
console.log("hello a");
b(c, d);
};function b(c, d) {
console.log("hello b");
c(d);
};
function c(d) {
console.log("hello c");
d()
};
function d() {
console.log("hello d");
};
a(b, c, d);
输出结果
hello a
hello b
hello c
hello d
如果回调函数写的多了,会造成代码特别特别恶心。









