什么是error事件?
EventEmitter定义的特殊的时间,包含错误语义,当遇到异常时会触发error时间,如果没有对应的异常监听器,那么Node.js会把它当做异常,退出程序并输出错误信息。
例如:
var ee = new events.EventEmitter();
ee.addListener('error',function () {
console.log("you need to deal with this error");
});
ee.emit('r');
运行结果如下:
虽然时间r我并没人为地进行监听,但运行时没有报错
var events = require('events');
var ee = new events.EventEmitter();
ee.addListener('error',function () {
console.log("you need to deal with this error");
});
ee.emit('error');
运行结果
这个名为‘error’的事件会报错,为了避免因为error事件的错发而报错,我们可以增加error的监听器
EventEmitter的继承:
所有支持事件相应的核心模块都是EventEmitter的子类:
- Javascript的对象机制基于原型,支持部分多重继承,继承EventEmitter不会打乱对象原来的关系
缓冲区:
1、相关知识
Javascript语言只有字符串数据类型没有二进制数据类型,因此,为了处理TCP/文件流,Node.js定义了Buffer类。Buffer类可以用来创建一个存放二进制数据的缓冲区。Buffer类的实例类似一个整数数组,对应的是V8堆内存之外的原始内存。
创建Buffer:
V6.0之前使用new Buffer进行创建(操作权限较大),V6.0之后建议使用buffer.from()接口创建Buffer类
- Buffer.alloc(size[, fill[, encoding]])
返回一个指定大小的 Buffer 实例,如果没有设置 fill,则默认填满 0
- Buffer.allocUnsafe(size)
返回一个指定大小的 Buffer 实例,但是它不会被初始化,所以它可能包含敏感的数据
- Buffer.allocUnsafeSlow(size)
- Buffer.from(array)
返回一个被 array 的值初始化的新的 Buffer 实例(传入的 array 的元素只能是数字,不然就会自动被0覆盖)
- Buffer.from(arrayBuffer[, byteOffset[, length]])
返回一个新建的与给定的 ArrayBuffer 共享同一内存的 Buffer。
- Buffer.from(buffer)
复制传入的 Buffer 实例的数据,并返回一个新的 Buffer 实例
- Buffer.from(string[, encoding])
返回一个被 string 的值初始化的新的 Buffer 实例
2、字符编码:
通过使用显示字符串编码,实现Buffer实例与javascript字符串之间的相互转换
例如:
const buf = Buffer.from('hello world','ascii');
console.log(buf.toString('utf-8'));
console.log(buf.toString('UCS2'));
运行结果如下:
源码分析
Buffer.from = function(param1, param2, param3){
};
该方法实现创建一个Buffer实例
==>第一个参数为缓冲区或者数组(非必须填)
==>第二个参数类型为(字符串/ int型)
字符串设定编码方式/int型设置第一个放置的数组位置的下标(仅针对ArrayBuffer类型)
==>第三个参数为int型,如果不设置默认为从该下标到数组最后位置的空间
返回一个缓冲区实例
Buffer.prototype.toString = function(encoding, start, end) {
return '';
};
将二进制数据按照一定类型转换成字符串
==>第一个参数为编码方式(默认编码方式为utf8)
==>第二个参数读取字节的起始位置
==>第三个参数决定读取的终止位置,默认为缓冲区结尾
如果缓冲区没有数据返回空,否则返回编码后的字符串
支持字符编码
ascii | 仅支持 7 位 ASCII 数据。如果设置去掉高位的话,这种编码是非常快的。 |
utf8 | 多字节编码的 Unicode 字符。许多网页和其他文档格式都使用 UTF-8 |
utf16le | 2 或 4 个字节,小字节序编码的 Unicode 字符。支持代理对(U+10000 至 U+10FFFF) |
ucs2 - utf16le | utf16le 的别名。 |
base64 | Base64 编码。 |
latin1 | 一种把 Buffer 编码成一字节编码的字符串的方式。 |
binary | latin1 的别名。 |
hex | 将每个字节编码为两个十六进制字符。 |
读写操作
写入:
buf.write(string[, offset[, length]][, encoding])
String-写入缓冲区的字符串
缓冲区开始写入的索引值
写入的字节数,默认为缓冲区的总大小
使用的编码,默认utf8
返回实际写入字符个数
注:如果字符串的大小大于缓冲区的大小,只尽量写满所有空间(如果最后一个字符不能完整写入则不写)
实例:
buf = Buffer.alloc(256);
len = buf.write("hello sunshine");
console.log(len);
运行结果:
读取数据:
buf.toString([encoding[, start[, end]]])
实例:
buf = Buffer.alloc(256);
for(var i = 0; i < 26; i++){
buf[ i ] = i+ 97;
}
console.log(buf.toString('utf-8'));
运行结果如下:
Buffer转换成JSON对象
buf.toJSON()
JSON.stringify()方法将JavaScript对象转换成JSON字符串,在调用JSON.stringify()方法时,会隐式地调用toJSON()
stringify(value: any, replacer?: (key: string, value: any) => any, space?: string | number): string;
- 参数1:一个javascript值,通常是被转换的一个对象或者是数组
- 参数2:转换的方法
- 参数3:间隔符号,使返回结果更容易读
注:是ES6中新增的语法
(x) => x + 6
相当于
function(x){
return x + 6;
};
JSON.parse(text: string, reviver?: (key: any, value: any) => any): any;
将数据转换成javascript对象
- JSON字符串
- 转换结果的函数【可选】
实例:
const buf = Buffer.from([0x1, 0x2, 0x3, 0x4, 0x5]);
const json = JSON.stringify(buf);
console.log(json);
console.log(JSON.parse(json));
const result = JSON.parse(json,(key,value) =>{
return value && value.type === 'Buffer' ?
Buffer.from(value.data):
value;
});
console.log(result);
运行结果如下:
node.js——绑定事件
node.js——error事件、缓冲区操作