博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Node.js Undocumented(1)
阅读量:5738 次
发布时间:2019-06-18

本文共 1468 字,大约阅读时间需要 4 分钟。

的API文档做的不是很好,有些部分干脆没文档,最终还是要看代码才能解决。我这里将记录下看源码过程中看到的一些API并补充一些测试例子。在玩的朋友可以瞧瞧。

process.reallyExit(status)

用于进程主动退出,status设置退出的状态码。请注意,reallyExit退出的进程不会调用’exit’事件,下面的代码不会有任何输出:

var interval=setInterval(function(){

process.reallyExit(1);
},1000);
process.on(‘exit’,function(){
console.log(“hello”);
});
process._kill(pid,sig)

用于给指定pid的进程发送指定信号(类似kill命令),这是个“private”方法,你需要慎重使用,下面的代码会杀死自身的进程:

var pid=process.pid

process._kill(pid,9);
process.binding(name)

非常有用的方法,很奇怪API文档里竟然没提到,这个方法用于返回指定名称的内置模块。例如下面的代码将打印node_net模块所有的可以调用的方法或变量(很多是文档没有提到的并且没有exports的,后续我会介绍下):

var binding=process.binding(‘net’);

console.dir(binding);

process.dlopen(filename,target)
看源码注释说是用来动态加载node.module的动态链接库的,以后尝试写扩展的时候也许可以尝试一下。

定时器

Node.js的定时器模块的实现是有讲究的,对于超时时间after<=0的callback,会在内部new一个Timer并start(本质是使用libev的timer机制);但是对于after>0的callback,却不是这样。因为在实际应用中,大多数定时器事件的超时时间都是一样的,如果每个事件都new一个Timer并start,代价太高。因此node.js采用了一个类似哈希表的方案,将相同after超时时间的定时器事件组织成链表,以after为key,以链表为value整体构成一张表。每个链表只new一个Timer,这个Timer负责整个链表的定时器事件,当某个事件超时调用后,利用ev_timer_again来高效地重新设置超时时间。
如果你确实希望对于after>0的定时器也每次new一个Timer来处理,那也可以做到,这就要用到前面提到的process.binding方法来获取timer模块,一个例子:

var Timer = process.binding(‘timer’).Timer;

var timer=new Timer();

timer.callback=function(){
console.log(“callback called”);
};
timer.start(1000,0);
timer.callback
设定timer的回调函数,当超时的时候调用。

timer.start(after,repeat)

启动定时器,在after毫秒之后调用超时回调;如果repeat==0,则自动停止定时器;如果repeat>0,则在repeat毫秒之后再次调用callback,以repeat毫秒为间隔不断重复下去。

本文来源于"阿里中间件团队播客",原文发表时间"  2011-07-06"

转载地址:http://jpbzx.baihongyu.com/

你可能感兴趣的文章
TiDB 源码阅读系列文章(七)基于规则的优化
查看>>
面试中会遇到的正则题
查看>>
Spring之旅第八站:Spring MVC Spittr舞台的搭建、基本的控制器、请求的输入、表单验证、测试(重点)...
查看>>
数据结构与算法——常用排序算法及其Java实现
查看>>
你所不知的Webpack-多种配置方法
查看>>
React.js 集成 Kotlin Spring Boot 开发 Web 应用实例详解
查看>>
webpack+typescript+threejs+vscode开发
查看>>
python读excel写入mysql小工具
查看>>
如何学习区块链
查看>>
搜索问题的办法
查看>>
微信分销系统商城营销5大重点
查看>>
求职准备 - 收藏集 - 掘金
查看>>
htm5新特性(转)
查看>>
Linux-Centos启动流程
查看>>
php 设计模式
查看>>
后端技术精选 - 收藏集 - 掘金
查看>>
Laravel 服务容器
查看>>
mac安装kubernetes并运行echoserver
查看>>
多页架构的前后端分离方案(webpack+express)
查看>>
算法(第4版) Chapter 1
查看>>