What is flow control?

和其它语言一样,Node.js 在代码编写时,如何组织代码,如何写出clean code都是不可避免的难点。

同时,由于Node.js的天然特性(异步,事件驱动),良好的代码组织就更为重要。

所谓的flow control指的是序列化的执行一个个node.js task的代码组织手段。

与其它语言一样,任务流可以被组织成两种(串行,并行)如下图:

How to flow control?

一种方式是使用node.js 社区提供的各类第三方模块(),另一种方式就是我们自己编写相关代码。为了工程开发的效率,用第三方库当然是更好的选择,但是为了更好的了解node.js的异步原理,我们可是自己试着实现两种流控制。

A simple demo of serial flow control

以下的代码实现了每隔一秒输出不同文字的功能。

setTimeout(function () {
    console.log("First");
    setTimeout(function () {
        console.log("Sencond");
        setTimeout(function () {
            console.log("Third");
        }, 1000);
    }, 1000);
}, 1000);

如果用第三方库来实现串行流控制,代码会是这样的:

var flow = require('nimble');

flow.series([
    function (callback) {
        setTimeout(function () {
            console.log("First");
            callback();
        }, 1000)
    },
    function (callback) {
        setTimeout(function () {
            console.log("Second");
            callback();
        }, 1000)
    },
    function (callback) {
        setTimeout(function () {
            console.log("Third");
            callback();
        }, 1000)
    }
]);

More code but more maintainable。特别是在串行调用链极长的时候,使用流控制的优势就非常明显了。

那我们自己要如何实现相关代码呢?下面就是例子:

var tasks = [
    function (callback) {
        setTimeout(function () {
            console.log("First");
            next();
        }, 1000)
    },
    function (callback) {
        setTimeout(function () {
            console.log("Second");
            next();
        }, 1000)
    },
    function (callback) {
        setTimeout(function () {
            console.log("Third");
            next();
        }, 1000)
    }
];

function next(){
    var currentTask = tasks.shift();
    if (currentTask) {
        currentTask();
    }
}

next();

OK,很简单吧,我们再来看并行。

Parallel flow control

以下代码假设我们跑了10个并行任务:

var taskCounter = 0;
var taskSum = 10;

function isTaskCompleted(){
    if (++taskCounter == taskSum) {
        console.log('All job done');       
    }
}

function Job(){
    //Lots of code here
    isTaskCompleted();
}

for(var i = 0; i < 10; i++)
    Job();

使用nimble来解决同样的问题:

var flow = require('nimble');

flow.parallel([
    Job(),
    Job(),
    Job(),
    Job(),
    Job(),
    Job(),
    Job()
]);

Summary

本文是对flow control做的很精简的总结,信息量不大,大家多多包涵。

 

Node.js学习笔记 02 Implementing flow control的更多相关文章

  1. 一点感悟:《Node.js学习笔记》star数突破1000+

    写作背景 笔者前年开始撰写的<Node.js学习笔记> github star 数突破了1000,算是个里程碑吧. 从第一次提交(2016.11.03)到现在,1年半过去了.突然有些感慨, ...

  2. Node.js学习笔记(3):NPM简明教程

    Node.js学习笔记(3):NPM简明教程 NPM常用操作 更新NPM版本 npm install npm -g -g,表示全局安装.我们可以指定更新版本,只需要在后面填上@版本号即可,也可以输入@ ...

  3. 系列文章--Node.js学习笔记系列

    Node.js学习笔记系列总索引 Nodejs学习笔记(一)--- 简介及安装Node.js开发环境 Nodejs学习笔记(二)--- 事件模块 Nodejs学习笔记(三)--- 模块 Nodejs学 ...

  4. Node.js学习笔记(2):基本模块

    Node.js学习笔记(2):基本模块 模块 引入模块 为了编写可维护的代码,我们把很多函数分组,分别放到不同的文件里,这样,每个文件包含的代码就相对较少,很多编程语言都采用这种组织代码的方式.在No ...

  5. Node.js学习笔记(1):Node.js快速开始

    Node.js学习笔记(1):Node.js快速开始 Node.js的安装 下载 官方网址:https://nodejs.org/en/ 说明: 在Windows上安装时务必选择全部组件,包括勾选Ad ...

  6. Node.js学习笔记(4):Yarn简明教程

    Node.js学习笔记(4):Yarn简明教程. 引入Yarn NPM是常用的包管理工具,现在我们引入是新一代的包管理工具Yarn.其具有快速.安全.可靠的特点. 安装方式 使用npm工具安装yarn ...

  7. Node.js学习笔记(一)

    1.回调函数 node是一个异步事件驱动的平台,所以在代码中我们经常需要使用回调函数. 例: setTimeout(function(){ console.log('callback is calle ...

  8. Node.js学习笔记(一):快速开始

    最近接了一个node项目,虽然最后顺利完成了,但是由于第一次实战,整个过程是赶出来的,许多地方一知半解.现在项目结束了,就静下心来系统地学一学,理一理,读书不忘拿笔,既然读书了,当然就要记点东西.一方 ...

  9. Node.js学习笔记(一)基础介绍

    什么是Node.js 官网介绍: Node.js® is a JavaScript runtime built on Chrome's V8 JavaScript engine. Node.js us ...

随机推荐

  1. python学习(二):python基本语法

    前言:python基本的语法与其他语言诸如C,JAVA等类似,但个中有些许不同. 一.常规语法 1.变量名与关键字 与其他语言类似,变量名由字母.数字.下划线组成,且必须由字母开头. 变量使用不需要提 ...

  2. 基础字符串处理_C++

    C++中,有 char [ ] 和 string 两种方式处理字符串 char 数组是最原始的,string 是带迭代器的 正是这种 string 带了迭代器,它会使我们处理字符串很方便,但也十分慢 ...

  3. WM_INITDIALOG与WM_CREATE消息的区别

      WM_CREATE是所有窗口都能响应的消息,表明本窗口已经创建完毕(可以安全的使用这个窗口了,例如在它上面画控件等).在响应WM_CREATE消息响应函数的时候,对话框及子控件还未创建完成,亦是说 ...

  4. 蛮考验基础的JS笔试题(有坑小心!)

    1.  考察this var length = 10 function fn(){ alert(this.length) } var obj = { length: 5, method: functi ...

  5. biji001

    指针对变量使对指向变量的指针&运算符产生,对指针使用*运算符则可以返回到原始变量只要p指向i,那么*p就是i的别名*p不仅仅拥有和i同样的值,而且对*p的改变i的值*p左值,对它赋值合法*p ...

  6. SDL2 Tutorial

    Hello World for SDL2 SDL2 setting for visual studio. http://lazyfoo.net/tutorials/SDL/01_hello_SDL/w ...

  7. 关于<html>标签里的class= no-js

    最近研究bootstrap的时候,发现了一个案例网站有一段 <html class="no-js"> 然后问了下度娘,找到了一篇大神的文章 里面对这个有很详细的解释: ...

  8. C# (GDI+相关) 图像处理(各种旋转、改变大小、柔化、锐化、雾化、底片、浮雕、黑白、滤镜效果) (转)

    C#图像处理   (各种旋转.改变大小.柔化.锐化.雾化.底片.浮雕.黑白.滤镜效果)     一.各种旋转.改变大小   注意:先要添加画图相关的using引用.   //向右旋转图像90°代码如下 ...

  9. 基于opencv网络摄像头在ubuntu下的视频获取

     基于opencv网络摄像头在ubuntu下的视频获取 1  工具 原料 平台 :UBUNTU12.04 安装库  Opencv-2.3 2  安装编译运行步骤 安装编译opencv-2.3  参 ...

  10. [leetcode]_Pascal's Triangle II

    题目:Pascal三角的变形,要求只用O(K)的额外空间. 思路:由于Pascal三角中,tri[n][i] = tri[n - 1][i] + tri[n-1][i-1],(通常情况下) 如果已经获 ...