zoukankan      html  css  js  c++  java
  • nj08---process、console

    概念:所有属性都可以在程序的任何地方访问,即全局变量。在JavaScript中,通常window是全局对象,而Node.js的全局对象是global,所有全局变量都是global对象的属性,如:console、process等。
    
    一、全局对象与全局变量
    global最根本的作用是作为全局变量的宿主。满足以下条件成为全局变量:
    1.在最外层定义的变量
    2.全局对象的属性
    3.隐式定义的变量(未定义直接赋值的变量)
    在Node.js中不可能在最外层定义变量,因为所有用户代码都是属于当前模块的,而模块本身不是最外层上下文。
    
    二、process
    它用于描述当前Node.js进程状态的对象。提供了一个与操作系统的简单接口,通常写本地命令行程序的时候,会用到它。
    1.process.argv是命令行参数数组,第一个元素是node,第二个元素是脚本文件名,第三个元素开始每个元素是一个运行参数。console.log(process.argv);
    /*node argv.js '11' '22' 33 oo
    输出:node.exe 
    argv.js 
    '11' 
    '22' 
    33 
    'oo'*/
    2.process.stdout是标准输出流,进入node环境,通常我们使用的console.log()  其底层是用 process.stdout.write();实现。
    3.prcess.stdin是标准输入流,初始时它是被暂停的。要想从标准输入流读取数据,必须恢复流,并手动编写流的事件相应函数。//恢复流
    process.stdin.resume();
    process.stdin.on('data',function(data){
        process.stdout.write('read from console'+data.toString());
    })
    //node stdin.js 然后输入,可以一直输入
    4.process.nextTick(callback)的功能是为事件循环设置一项任务。Node.js会在下次事件循环调响应时调用callback
    Node.js适合IO密集型的应用,而不是计算密集型的应用。process.nextTick()提供了一个这样工具,可以把复杂的工作拆散,成较小的事件去执行。
     
    function doSomething(args,callback){
        somethingComplited(args);
            callback();
    }      
    doSomething('12345',function onEnd(){
        compute();
    })
    如果假设compute()和somethingComplited()是两个较为耗时的函数。以上的程序在调用doSomething时会先执行somethingComplited(args),然后立即调用回调函数,在onEnd()中又会执行compute(),改写为:
    
    
    function doSomething(args,callback){
        somethingComplited(args);
        process.nextTick(callback);
    }
    使用process.nextTick()后,改写后的程序会把上面耗时的操作拆分为两个事件,减少每个事件的执行时间,提高事件相应速度。function compute(){
    console.log("I am is cpmpute method");
    }
    function somethingComplited(args){
        console.log("I am is somethingComplited method");
        console.log(args);
    }
    //function doSomething(args,callback){
    //    somethingComplited(args);
    //    callback();
    //}
    function doSomething(args,callback){
        somethingComplited(args);
        process.nextTick(callback);//这个方法是异步执行
    }
    doSomething('12345',function onEnd(){
        compute();
    })
    
    5.process其他方法:process.platform()、process.pid()、process.execPath()、process.memoryUsage()等方法。。。
        API链接:http://nodejs.org/api/process.html
        
    二、console
    java中的log4j的   Logger logger=new Logger(Object.class);
              logger.info
              logger.error
              logger.debug
              
    用于提供控制台标准输出,Node.js沿用了这个标准,提供与习惯行为一直的console对象。
    1.console.log().向标准输出流打印字符并以换行符结束。
    使用案例:
            console.log("hello");
            console.log("hello%marico");
            console.log("hello%marico"," Mr. ");
    2.console.error();用法与console.log()相同,只是向标准错误流输出。
    3.console. trace();向标准错误六输出当前的调用栈
    console.log("hello"); 
     console.log('hello%marico');
     console.log('hello%marico',1991,'yfc');
     console.error('error!');
     console.trace('this is a error');
     /*
     hello
    hello%marico
    hello%marico 1991
     */
  • 相关阅读:
    一行代码解决各种IE兼容问题,IE6,IE7,IE8,IE9,IE10(如果今天你的老板还在要求你兼容IE6~8,别犹豫,辞职吧。)
    HTML元素分类【三种类型】
    React-Native 学习笔记-Android开发平台-开发环境搭建
    常用原生JS函数和语法集合
    jQuery选择器总结
    jQuery选择器大全
    Sublime Text 3 的HTML代码格式化插件Tag
    用CSS画三角形
    纯CSS绘制三角形(各种角度)
    纯CSS写三角形-border法[晋级篇01]
  • 原文地址:https://www.cnblogs.com/yaowen/p/7014285.html
Copyright © 2011-2022 走看看