nodejs异步调用async
犹豫nodejs是异步编程模型,有一些在同步编程中很容易做到的事情,现在却变得很麻烦,async的流程控制就是为了简化这些操作
var async = require('async'); 1、series(多个函数一次执行,之间没有数据交换)
series(tasks,[callback])顺序执行数组、集合内的函数,当前面一个函数执行完成就会立即执行下一个函数,如果函数触发了错误,可以在callback函数中验证,否则会一直执行完成tasks
有多个异步函数需要依次调用,一个完成之后才能执行下一个,各函数之间没有数据的交换,仅仅需要保证其执行顺序,这时可以使用series。
tasks传的是一个数组函数
const async=require('async');
async.series([
function(callback){
console.log("one");
callback(null,"one");
},
function(callback){
console.log("two");
callback(null,"two");
}
],function(err,results){
console.log("err======"+err);
console.log("results======"+results);
console.log("typeof results======"+typeof (results));
})
运行之后输出:
one
two
err======null
results======one,two
typeof results======object
我觉得这里很重要的是err是上面两个函数的错误信息,而results这个参数是一个数组对象,他们的值是上面数组函数每个callback里面的参数
以上代码详解:
1、依次执行一个函数数组中的每个函数,每一个函数执行完成之后才能执行下一个函数。
2、如果任何一个函数向它的回调函数中传了一个error,则后面的函数都不会被执行,并且将会立刻将该error以及已经执行了的函数的结果传给series中最后的那个callback
3、当所有的函数执行完后(没有出错),则会把每个函数传给其回调函数的结果合并为一个数组,传递给series最后的那个callback。
4、还可以json的形式来提供tasks。每个属性都会被当作函数来执行,并且结果也会以json形式传给series最后那个callback,这种方式可读性更高一些。
5、如果中间某个函数出错,series函数如何处理:中间有函数出错。出错之后的函数不会执行,错误及之前正常执行的函数结果将传给最终的callback。
6、如果某个函数传给回调的值是undefined,null,{},[]等,series如何处理:如果某个函数传的数据是undefined, null, {}, []等,它们会原样传给最终callback。
7、另外还需要注意的是:多个series调用之间是不分先后的,因为series本身也是异步调用。
模拟series多个函数中一个出错会如何
const async=require('async');
async.series([
function(callback){
console.log("one");
callback("error","one");
},
function(callback){
console.log("two");
callback(null,"two");
}
],function(err,results){
console.log("err======"+err);
console.log("results======"+results);
console.log("typeof results======"+typeof (results));
})
运行后输出:
one
err======error
results======one
typeof results======object
传json形式tasks
代码:
const async=require("async");
async.series({
one:function(callback){
setTimeout(function(){
callback(null,1);
},200)
},
two:function(callback){
setTimeout(function(){
callback(null,2);
})
}
},function(err,results){
console.log("results0====="+results['one']);
console.log("results1====="+results['two']);
})
运行后输出:
results0=====1
results1=====2
这是一个json格式的results
2、parallel
parallel(tasks,[callback])并行执行数组集合内的方法,不用等到前一个函数执行完再执行下一个函数,如果函数促发了错误,可以再callback函数中验证
并行执行多个函数,每个函数都是立即执行,不需要等待其它函数先执行。传给最终callback的数组中的数据按照tasks中声明的顺序,而不是执行完成的顺序。
如果某个函数出错,则立刻将err和已经执行完的函数的结果值传给parallel最终的callback。其它未执行完的函数的值不会传到最终数据,但要占个位置。
同时支持json形式的tasks,其最终callback的结果也为json形式。
const async=require('async');
async.parallel([
function(callback){
setTimeout(function(){
callback(null,"one");
},200)
},
function(callback){
setTimeout(function(){
callback(null,"two");
},100);
}
],
function(err,results){
console.log("err====="+err);
console.log("results====="+results);
})
运行后输出:
err=====null
results=====one,two
代码:
const async=require('async');
async.parallel([
function(callback){
setTimeout(function(){
callback(null,"one");
},400)
},
function(callback){
setTimeout(function(){
callback("err","two");
},200);
},
function(callback){
setTimeout(function(){
callback(null,"three");
},100);
}
],
function(err,results){
console.log("err====="+err);
console.log("results====="+results);
})
运行后输出:
err=====err
results=====,two,three
代码:
const async=require('async');
async.parallel({
one:function(callback){
setTimeout(function(){
callback(null,"one");
},400)
},
two:function(callback){
setTimeout(function(){
callback(null,"two");
},200);
},
three:function(callback){
setTimeout(function(){
callback(null,"three");
},100);
}
},
function(err,results){
console.log("err====="+err);
console.log("results====="+results['one']);
console.log("results====="+results['two']);
console.log("results====="+results['three']);
})
运行后输出:
err=====null
results=====one
results=====two
results=====three
3、waterfall
waterfall(tasks,callback),多个函数依次执行,且前一个的输出为吼一个的输入,
与series相似,按顺序依次执行多个函数,不同之处是,每个函数产生的值,都将传给下一个函数,如果中途出错,后面的函数将不会被执行。错误信息以及之前产生的结果,将传给waterfall最终的callback;该函数不支持json格式的tasks,
* 注意,所有的callback都必须形如callback(err, result),但err参数在前面各函数中无需声明,它被自动处理。
中途有函数出错,其err和产生的值将直接传给最终callback,后面的函数不再执行
代码:
const async=require('async');
async.waterfall([
function(callback){
callback(null,'one','two');
},function(args,arg2,callback){
callback(null,'three');
},function(arg1,callback){
callback(null,'done');
}
],function(err,results){
console.log("results====="+results);
})
运行后输出:
results=====done
代码:
const async=require('async');
async.waterfall([
function(callback){
callback(null,'one','two');
},function(args,arg2,callback){
callback("err",'three');
},function(arg1,callback){
callback(null,'done');
}
],function(err,results){
console.log("results====="+results);
})
运行后输出:
results=====three
4、whilst
whilst(test,fn,callback),可用于异步调用的while,第一个参数为验证条件,第二个参数为执行函数,第三个参数为验证失败后回调函数,一般在延迟动画用的比较多
相当于while,但其中的异步调用将在完成后才会惊醒下一次循环,
代码:
const async=require('async');
var count=0;
async.whilst(
function(){ //验证成功继续,失败回调
return count<5;
},
function(callback){ //1秒过去该函数回调执行完毕,接着循环,知道count=5的时候,第一个方法过不去了,报错,走到第三个方法
console.log("count"+count);
count++;
setTimeout(callback,1000);
},
function(err){
console.log("err"+err);
}
)
代码运行后输出:
count0
count1
count2
count3
count4
errnull
该函数的功能比较简单,条件变量通常定义在外面,可供每个函数访问,在循环中,异步调用时产生的值实际上被丢弃了,因为最后那个callback只能传入错误信息。
另外,第二个函数fn需要能接受一个函数cb,这个cd最终必须被执行,用于表示出错或正常结束
中途出错。出错后立刻调用第三个函数。
代码:
const async=require('async');
var count=0;
async.whilst(
function(){ //验证成功继续,失败回调
return count<5;
},
function(callback){ //5秒过去后
console.log("count"+count);
count++;
if(count===1){
callback("err");
}else{
setTimeout(callback,1000);
}
},
function(err){
console.log("err"+err);
}
)
运行后输出:
count0
errerr
第二个函数即使产生值,也会被忽略。第三个函数只能得到err。
5、eachLimit
eachLimit(arr, limit, iterator, callback)批量遍历集合。同一时候只会执行limit个任务。遍历过程有异常通过cb返回,进程不会中断,直到全部遍历完成后err在最后的回调函数返回。
- async.eachLimit([1, 2, 3, 4, 5, 6, 7, 8], 2, function(item, cb) {
- console.info(item);
- if (item == 4) {
- cb('throw err: ' + item);
- } else {
- cb();
- }
- }, function(err) {
- console.info('catch err: ' + err);
- });
nodejs异步调用async的更多相关文章
- SpringBoot学习笔记(七):SpringBoot使用AOP统一处理请求日志、SpringBoot定时任务@Scheduled、SpringBoot异步调用Async、自定义参数
SpringBoot使用AOP统一处理请求日志 这里就提到了我们Spring当中的AOP,也就是面向切面编程,今天我们使用AOP去对我们的所有请求进行一个统一处理.首先在pom.xml中引入我们需要的 ...
- springboot:异步调用@Async
在后端开发中经常遇到一些耗时或者第三方系统调用的情况,我们知道Java程序一般的执行流程是顺序执行(不考虑多线程并发的情况),但是顺序执行的效率肯定是无法达到我们的预期的,这时就期望可以并行执行,常规 ...
- springboot 异步调用Async使用方法
引言: 在Java应用中,绝大多数情况下都是通过同步的方式来实现交互处理的:但是在处理与第三方系统交互的时候,容易造成响应迟缓的情况,之前大部分都是使用多线程来完成此类任务,其实,在spring 3. ...
- springboot之异步调用@Async
原文:http://www.cnblogs.com/xuwenjin/p/8858050.html 引言: 在Java应用中,绝大多数情况下都是通过同步的方式来实现交互处理的:但是在处理与第三方系统交 ...
- SpringBoot集成篇(二) 异步调用Async
什么是异步调用? 异步调用是相对于同步调用而言的,同步调用是指程序按预定顺序一步步执行,每一步必须等到上一步执行完后才能执行,异步调用则无需等待上一步程序执行完即可执行. 如何实现异步调用? 多线程, ...
- 170719、springboot编程之异步调用@Async
1.在pom.xml中增加依赖 <dependency> <groupId>org.springframework.boot</groupId> <artif ...
- SpringBoot系列:Spring Boot异步调用@Async
在实际开发中,有时候为了及时处理请求和进行响应,我们可能会多任务同时执行,或者先处理主任务,也就是异步调用,异步调用的实现有很多,例如多线程.定时任务.消息队列等, 这一章节,我们就来讲讲@Async ...
- SpringBoot异步调用--@Async详解
1. 概述 在日常开发中,为了提高主线程的效率,往往需要采用异步调用处理,例如系统日志等.在实际业务场景中,可以使用消息中间件如RabbitMQ.RocketMQ.Kafka等来解决.假如对高可用 ...
- Nodejs异步框架——async
上次的网页爬虫写完后,又打算做一个爬图的工具.前两天已经写好了代码.思路如下: 分析页面还是采用cheerio,对<div>中的img进行分析抽取,拿到图片的url.然后用childpro ...
随机推荐
- python 动态语言 __slots__
python 是动态语言,就是说可以动态的创建属性, 别的语言不行,再创建类的时候已经规定好了 使用__slots__,注意要用tuple定义同意绑定的属性名称,仅对当前类起作用,对继承的子类是不起作 ...
- VC++ 汇编相关的东西
Tips: VC++在新建一个.asm文件后必须重新导入project中才能进行编译. 下面是一个汇编与C++相互调用的例子: Main.cpp #include <stdio.h> #i ...
- 用Python和py2app写独立的Mac OS X 应用
文/lovexiaov(简书作者)原文链接:http://www.jianshu.com/p/afb6b2b97ce9著作权归作者所有,转载请联系作者获得授权,并标注“简书作者”. 前提 创建一个普通 ...
- Laravel5.1 数据库--DB运行原生SQL
Laravel操作数据库有三种:DB原生SQL.构建器.Model.这三种依情况而决定使用哪种更合适. 那么今儿咱就从DB原生SQL说起: 1 用DB门面原生SQL语句操作 用DB门面操作的话呢 无非 ...
- linux以下C 利用openssl的AES库加密,解密
OpenSSL提供了AES加解密算法的API const char *AES_options(void); AES算法状态,是所有支持或者是部分支持. 返回值:"aes(full)" ...
- Python 邮箱
#coding:utf-8from email.header import Headerfrom email.mime.text import MIMETextfrom email.utils imp ...
- php 代码的执行
PHP内核的实现和世界上绝大数的程序一样,接收输入数据,做相应处理后输出结果.用PHP编写的代码就是输入数据,PHP内核对编写的代码进行解释和运算,最后返回运算结果.当编写的PHP代码给内核去执行的时 ...
- keras常用的网络层
一.常用层 常用层对应于core模块,core内部定义了一系列常用的网络层,包括全连接.激活层等. 1.Dense层 Dense层:全连接层. keras.layers.core.Dense(outp ...
- 《从零开始学Swift》学习笔记(Day 12)——说几个特殊运算符
原创文章,欢迎转载.转载请注明:关东升的博客 除了一些常用的运算符,还有一些其他的: • 引用号(.):实例调用属性.方法等操作符. • 问号(?):用来声明可选类型. • ...
- 关于微信小程序下拉出现三个小点
包子这天看美团外卖的小程序,再瞅瞅自己的背景色,发现,美团下拉的时候有三个小点,但是我自己的校车徐下拉的时候没有三个小点,很是郁闷,于是各种的找各种的找,发现,这三个小点是微信小程序自带的,你只需要设 ...