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
 */
时间: 2024-11-02 23:33:48

nj08---process、console的相关文章

Chrome开发者工具详解(1):Elements、Console、Sources面板

Chrome开发者工具面板 面板上包含了Elements面板.Console面板.Sources面板.Network面板. Timeline面板.Profiles面板.Application面板.Security面板.Audits面板这些功能面板. 这些按钮的功能点如下: Elements:查找网页源代码HTML中的任一元素,手动修改任一元素的属性和样式且能实时在浏览器里面得到反馈. Console:记录开发者开发过程中的日志信息,且可以作为与JS进行交互的命令行Shell. Sources:断

webpack和vue的按需加载组件、console、抓包

1.webpack和vue的按需加载组件 webpack特有的懒加载文件的方式,很大的提升了webpack打包SPA应用的在性能方面. 而从webpack2以后require.ensure已经被import()替换. const Recommend = (resolve) => { import('components/recommend/recommend').then((module) => { resolve(module) }) } export default new Router(

u-boot串口和stdio、console初始化及相关操作详解<三>

console是构建在stdio之上的,console的初始化是board_r中最后收尾的操作. console的初始化函数console_init_r在common/console.c中实现: int console_init_r(void) { char *stdinname, *stdoutname, *stderrname; struct stdio_dev *inputdev = NULL, *outputdev = NULL, *errdev = NULL; #ifdef CONFI

java控制台输入Scanner、InputStreamReader、Console说明

java控制台输入 (2009-12-08 11:13:28) 转载▼ 标签: 杂谈 分类: corejava 0 引言从控制台中读取数据是一个比较常用的功能,在 JDK 5.0 以前的版本中的实现是比较复杂的,需要手工处理系统的输入流.有意思的是,从 JDK 5.0 版本开始,能从控制台中输入数据的方法每增加一个版本号,就有一种新增的方法,这也增加了选择的种类,可以依据不同的要求来进行选择.下面来看一下,各个版本中如何从控制台中读取数据以及各自的优缺点. 1 JDK 1.4 及以下版本读取的方

JS的六大对象:Global、Math、Number、Date、JSON、console,运行在服务器上方的支持情况分析

在ASP中使用runat="server"来调用JS的相关函数,代码如下: <script runat="server" language="javascript"> // 代码部份 </script> 下表列举JS六大对象在runat="server"中的支持情况: 对象 是否支持 Global 支持 Math 支持 Number 支持 Date 不支持 JSON 不支持 console 不支持 原文

0088 JavaScript输入输出语句:alert、console.log、prompt

为了方便信息的输入输出,JS中提供了一些输入输出语句,其常用的语句如下: 方法 说明 归属 alert(msg) 浏览器弹出警示框 浏览器 console.log(msg) 浏览器控制台打印输出信息 浏览器 prompt(info) 浏览器弹出输入框,用户可以输入 浏览器 注意:alert() 主要用来显示消息给用户,console.log() 用来给程序员自己看运行时的消息. 原文地址:https://www.cnblogs.com/jianjie/p/12127358.html

node.js之CommonJS

1. ( function(exports, require, module, __filename, __dirname) { console.log('This is a test.'); } ); - 每个文件是一个模块,有自己的作用域 - 在模块内部module变量代表模块本身 - module.exports属性代表模块对外接口 2.require特性 - module被加载时执行,加载后缓存 - 一旦出现某个模块被循环加载,就只会输出已经执行的部分,还未执行的部分不输出.开发中要避免

Vue.js 基础指令实例讲解(各种数据绑定、表单渲染大总结)——新手入门、高手进阶

Vue.js 是一套构建用户界面的渐进式框架.他自身不是一个全能框架--只聚焦于视图层.因此它非常容易学习,非常容易与其它库或已有项目整合.在与相关工具和支持库一起使用时,Vue.js 也能完美地驱动复杂的单页应用.他是基于AnjularJs 编写的,所以和前者的语法特别相似,却又使用简洁了很多. 那今天,我就给大家详细的说道说道这个 Vue.js ,以下是我们这次详解的目录,朋友们可以根据自己的情况选择性阅读,所有操作均附有代码实现. 1. Vue.js 如何绑定到页面中,使用他的功能. 2.

NodeJS入门(五)—— process对象

process对象用于处理与当前进程相关的事情,它是一个全局对象,可以在任何地方直接访问到它而无需引入额外模块. 它是 EventEmitter 的一个实例. 本章的示例可以从我的Github上下载到(敏感时期GFW发大招,git暂时传不了,等多几天风头过了再试着上传). 事件'exit' 当进程将要退出时触发.这是一个在固定时间检查模块状态(如单元测试)的好时机.需要注意的是 'exit' 的回调结束后,主事件循环将不再运行,所以计时器也会失效: process.on('exit', func