进程管理

1.调用终端命令实现目录目录拷贝

var child_procress = require('child_procress');
var util = require('util');

function copy(source, target, callback){
    child_procress.exec(util.format('cp -r %s/* %s', source, target), callback);
}

copy('a', 'b', function(err){
    // ...
});

2.Process

3.Child Procress

4.Cluster

进程管理有好多东西,但是却不是能写清楚的,具体需要什么怎样运行,其实都是具体情况具体分析,需要的时候查询官方API是个不错的办法。

异步编程

事件机制和异步IO是nodejs的特点。如果不会异步编程,那岂不是说nodejs没什么意思了吗!

1.回调

function heavyCompute(n, callback){
    var count = 0, i, j;
   
    for(i = n; i > 0; --i){
        for(j = n; j > 0; --j){
            count += 1;
        }
    }
   
    callback(count);
   
}

heavyCompute(10000, function(count){
    console.log(count);
});

console.log('hello');

//100000000

//hello

上面的程序是单线程的。

setTimeout(function(){
    console.log('world');
}, 1000);

console.log('hello');

//hello

//world

setTimeout在JS规范外,由运行环境提供的特殊函数创建一个平行进程后立即返回继续执行后续代码,平行线程执行完成后通知回来继续执行回调函数。setinterval,fs.readFile都是这样异步的。

平行线程执行完成工作,通知主线程,主线程如果在忙,则不会立刻执行,而是要等到主线程空闲时才会执行相关操作。

2.代码设计模式

1)函数返回值

//同步

var output = fn1(fn2('input'));

//异步方式

fn2('input', function(output2){
    fn1(output2, function(output1){
       
    });
});

2)遍历数组

//同步
var len = arr.length, 1=0;
for(;i<len;i++){
    arr[i]=sync(arr[i]);
}

//异步

(function next(i, len, callback){
    if(i<len){
        async(arr[i], function(value){
            arr[i]=value;
            next(i+1,len,callback);
        });
    }else{
        callback();
    }
}(0, arr.length, function(){
   
}));

//如果数据数组数据可以并行处理,但是后续代码需要数据数组数据全部处理好的情况下
(function(i, len, count, callback){
    for(;i<len;++i){
        (function(i){
            async(arr[i], function(value){
                arr[i]=value;
                if(++count===len){
                    callback();
                }
            });
        });
    }
}(0, arr.length, 0, function(){
    //init finish
}));

3)异常处理

try-catch

function sync(fn){
    return fn();
}

try{
    sync(null);
}catch(err){
    console.log('err::', err.message);
}
//=>object is not a function

4)域

如果按照上面的方法写,如果是函数多层调用,那代码就太丑了,在上面贴了一个那样的例子,系统提示,代码太丑无法显示,哎,算了,去掉吧,哈哈。因此NodeJS提供domain简化异常处理。用process捕获全局异常。

process.on('uncaughtException', function(err){
    console.log('ERR::', err.message);
});
setTimeout(function(fn){
    fn();
});

function async(request, callback){
    //Do something
    asyncA(request, function(data){
        //Do something
        asyncB(request, function(data){
            //Do something
            asyncC(request, function(data)){
                // Do something
                callback(data);
            }
        });
    });
}

http.createServer(function(request, response){
    var d = domain.create();
   
    d.on('error', function(){
        response.writeHead(500);
        response.end();
    });
   
    d.run(function(){
        async(request, function(data){
            response.writeHead(200);
            response.end(data);
        });
    });
});

【nodejs学习】3.进程管理及异步编程的更多相关文章

  1. Linux学习之进程管理(十九)

    Linux学习之进程管理 进程查看 查看系统中所有进程,使用BSD操作系统的格式 语法:ps aux 选项: a:显示所有前台进程 x:显示所有后台进程 u:显示这个进程是由哪个用户产生的 语法:ps ...

  2. Linux学习之进程管理

    |-进程管理     进程常用命令        |- w查看当前系统信息        |- ps进程查看命令        |- kill终止进程        |- 一个存放内存中的特殊目录/p ...

  3. Linux零起点之进程管理----c语言编程

    进程 (Process)是指操作系统中被加载到内存中的.正在运行的应用程序实例.进程是系统资源分配的基本单元,在其生命周期内会使用系统中的各种资源.进程主要由程序.数据以及进程控制快(PCB)3个部分 ...

  4. Linux系统学习之进程管理

    什么是进程? 进程表示程序的一次执行过程,它是应用程序的运行实例,是一个动态的过程.或者可以更简单地描述为:进程是操作系统当前运行的程序.当一个进程开始运行时,就要启动了这个过程.进程包括动态的执行的 ...

  5. perl学习之进程管理

    系统函数 == 最简单的系统调用  system "date"; # Perl会将 date 命令传递给unix的shell并获取返回值和error信息等   == 带有系统参数的 ...

  6. linux内核学习之进程管理------task_struct结构体

    struct task_struct { volatile long state;    /* -1 unrunnable, 0 runnable, >0 stopped */ struct t ...

  7. nodejs学习以及SSJS漏洞

    0x01 简介 什么是nodejs,it's javascript webserver! JS是脚本语言,脚本语言都需要一个解析器才能运行.对于写在HTML页面里的JS,浏览器充当了解析器的角色.而对 ...

  8. nodejs 异步编程 教程(推荐)

    有异步I/O就需要异步编程.本课程将着重讲解在学习node.js中关于异步编程的一些问题,以及如何应对这些问题,帮助node.js初学者快速入门. 地址 http://www.hubwiz.com/c ...

  9. 深入理解 Python 异步编程(上)

    http://python.jobbole.com/88291/ 前言 很多朋友对异步编程都处于"听说很强大"的认知状态.鲜有在生产项目中使用它.而使用它的同学,则大多数都停留在知 ...

随机推荐

  1. 关于C++的变量和类的声明和定义

    什么是变量?变量或者叫对象,是一个有具名的.可以供程序操作的存储空间.这里具名是指变量是有名字的,可供操作是指能进行加减乘除或者输入输出等操作,存储空间则是指有一块属于它的内存空间. 为了便于说明,标 ...

  2. javascript时钟

    <script language="JavaScript" type="text/javascript">         function now ...

  3. PHP中检测ajax请求的代码例子

    多数情况下,基于JavaScript 的Js框架如jquery.Mootools.Prototype等,在发出Ajax请求指令时,都会发送额外的 HTTP_X_REQUESTED_WITH 头部信息, ...

  4. Math对象

    <script type="text/javascript"> /* Math对象常用的方法: ceil 向上取整 floor() 向下取整 random() 随机数方 ...

  5. console调试--转

    目录: 一.什么是 Console 二 .什么浏览器支持 Console 三.为什么不直接使用 alert 或自己写的 log 四.console.log(object[,object,.....]) ...

  6. 数据库 数据库SQL语句五

    集合运算 union 并集(两个集合如果有重复部分,那么只显示一次重复部分) union all 并集(两个集合如果有重复部分,那么重复部分显示两次) intersect 交集 minus 差集 -- ...

  7. 怎么把QQ我的收藏表情图片转移到另一台电脑上

    把收藏的QQ表情从一台电脑转移到另一台电脑的操作步骤如下:    1.在有表情的电脑登陆QQ,随便打开一个聊天窗口,点击[表情],选择[表情设置],点击[导入导出表情包],选择[导出全部表情包]:   ...

  8. MYSQL如何导出存储过程和触发器?

    今天遇到.. 类似下面的就可以: mysqldump -u root -p -ntd -R  nxsc>nxsc_trigger.sql

  9. Smarty for foreach 使用

    {for} {for}{forelse}用于创建一个简单的循环. 下面的几种方式都是支持的: {for $var=$start to $end}步长1的简单循环. {for $var=$start t ...

  10. 如何右键新建HTML

    直接转载的,原文作者写的很详细:http://blog.csdn.net/ruanjiayou/article/details/51284864 14年在qq日志里写过 2014-10-25  htt ...