温馨提示×

温馨提示×

您好,登录后才能下订单哦!

密码登录×
登录注册×
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》

Node.js中的Buffer对象及创建方式是什么

发布时间:2022-01-11 14:46:18 来源:亿速云 阅读:119 作者:柒染 栏目:开发技术

Node.js中的Buffer对象及创建方式是什么,针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。

    什么是Buffer?

    js语言自身只有字符串数据类型,没有二进制数据类型,而处理TCP和文件流的时候,必须处理二进制数据。

    node.js提供了一个Buffer对象来提供对二进制数据的操作。

    Buffer 类在 Node.js 中是一个全局变量,在使用时无需引入模块,直接使用即可。

    Buffer 类的实例类似于整数数组,但 Buffer 的大小是固定的、且在 V8 堆外分配物理内存。 Buffer 的大小在被创建时确定,且无法调整。

    注意

    Buffer中存储的都是二进制数据,但是在显示时以16进制显示

    Buffer中每一个元素的范围从(00-ff)即(0-255)

    let str = 'Hello word'
    let buf = Buffer.from(str);
    //将字符串保存到Buffer中
    console.log(buf)//<Buffer 48 65 6c 6c 6f 20 77 6f 72 64>

    Buffer.length表示占用内存的大小

    由于汉字占3字节所以buf.length打印出来是12,而字符串的长度为8。

    let str = 'Hello 小萱'
    let buf = Buffer.from(str);
    
    console.log(str.length);//8
    console.log(buf.length);//12

    Buffer打印数字时会以十进制方式显示

    我们创建长度为5的的Buffer对象,并向里面添加字符和数字如下,我们分别打印字符和数字时会发现打印数字时会以十进制显示。

    let buf = Buffer.alloc(5);
    buf[0] = "a";
    buf[1] = 10;
    buf[2] = 15;
    buf[3] = 20;
    buf[4] = 25;
    console.log(buf[1])//10
    console.log(buf[2]);//15

    Buffer的创建方法

    通过Buffer的构造函数,但不推荐使用

    如创建一个指定大小的Buffer,

    let buf = new Buffer(10);
    console.log(buf);//<Buffer 00 00 00 00 00 00 00 00 00 00>

    我们打开node.js中文网官方文档,发现Buffer的构造方法全部都被弃用了,因此我就不重点写这部分了

    Node.js中的Buffer对象及创建方式是什么

    通过allocUnsafe方法

    语法:

    Buffer.allocUnsafe(size)

    size: 必选参数,Buffer 所需的长度。

    以这种方式创建的 Buffer 实例的底层内存不会被初始化。 新创建的 Buffer 的内容是未知的,可能包含敏感的数据。如果使用allocUnsafe方法,那么他在分配内存时没有清理数据,如果被分配的内存如果存在数据,那么就会造成数据泄漏。但是它的性能优于alloc方法。

    let buf = Buffer.allocUnsafe(10);
    console.log(buf);//<Buffer 00 00 4a 00 00 3c 00 00 90 00>

    通过alloc方法

    语法:

    Buffer.alloc(size[, fill[, encoding]])

    size :必选参数, Buffer 所需的长度。

    fill :可选参数,用于预填充新 Buffer 的值。 默认值: 0。

    encoding :可选参数,如果 fill 是字符串,则这就是它的编码。 默认值: &lsquo;utf8&rsquo;。

    创建一个指定大小为10的Buffer对象。

    其中传入必选参数10,那么它默认fill 为 undefined,则 Buffer 将以零填充。

    再传入可选参数fill为1,则以1填充

    最后可以传入fill的编码格式,表示fill将以什么方式编码

    let buf = Buffer.alloc(10);
    console.log(buf);//<Buffer 00 00 00 00 00 00 00 00 00 00>
    let buf1 = Buffer.alloc(10,1)
    console.log(buf1);//<Buffer 01 01 01 01 01 01 01 01 01 01>
    let buf2 = Buffer.alloc(10,1,"utf8")
    console.log(buf2);//<Buffer 01 01 01 01 01 01 01 01 01 01>

    alloc方法会初始化Buffer缓存区,它可确保新创建的 Buffer 实例的内容永远不会包含来自先前分配的敏感数据,包括可能尚未分配给 Buffer 的数据。

    通过Buffer.from()方法

    1、通过数组创建

    语法:

    Buffer.from(array)

    array:必选参数,用 0 &ndash; 255 范围内的字节 array 分配新的 Buffer。 该范围之外的数组条目将被截断以符合它。

    通过创建我们发现数组里面值的范围为00-FF,同时不能是字符类型的值。

    const buf = Buffer.from([1,3,5,7,4]);
    console.log(buf)//<Buffer 01 03 05 07 04>
    const  buf1 = Buffer.from(["a","b","c"]);
    console.log(buf1)//<Buffer 00 00 00>

    2、通过字符串创建
    语法:

    Buffer.from(string[, encoding])

    string :必选参数 要编码的字符串。
    encoding :可选参数 string 的编码。 默认值: &lsquo;utf8&rsquo;。

    const buf1 = Buffer.from('this is a example');
    console.log(buf1);//<Buffer 74 68 69 73 20 69 73 20 61 20 65 78 61 6d 70 6c 65>
    //通过ToString方法将它转化成字符串
    console.log(buf1.toString())//this is a example

    写入缓冲区

    语法:

    buf.write(string[, offset[, length]][, encoding])

    string :必选参数, 写入缓冲区的字符串。

    offset :可选参数,缓冲区开始写入的索引值,默认为 0 。

    length :可选参数,写入的字节数,默认为 buffer.length

    encoding :可选参数,使用的编码。默认为 &lsquo;utf8&rsquo; 。

    返回值:返回实际写入的大小。如果 buffer 空间不足, 则只会写入部分字符串。

    const buf = Buffer.alloc(256);
    const len = buf.write("this is a example");
    console.log("写入字节数 : "+len);//17

    从缓冲区读取数据

    语法:

    buf.toString([encoding[, start[, end]]])

    encoding :可选参数,使用的编码。默认为 &lsquo;utf8&rsquo; 。

    start :可选参数,指定开始读取的索引位置,默认为 0。

    end :可选参数,结束位置,默认为缓冲区的末尾。

    返回值:解码缓冲区数据并使用指定的编码返回字符串。

    buf = Buffer.alloc(26);
    for (let i = 0 ; i < 26 ; i++) {
        buf[i] = i + 65;
    }
    
    console.log( buf.toString('ascii'));       // 输出:ABCDEFGHIJKLMNOPQRSTUVWXYZ
    console.log( buf.toString('ascii',0,10));   //使用 'ascii' 编码, 并输出:ABCDEFGHIJ
    console.log( buf.toString('utf8',10,15));    // 使用 'utf8' 编码, 并输出: KLMNO
    console.log( buf.toString(undefined,15,26)); // 使用默认的 'utf8' 编码, 并输出: PQRSTUVWXYZ

    将 Buffer 转换为 JSON 对象

    语法:

    buf.toJSON()

    返回值:返回 JSON 对象。

    const buf = Buffer.from([0x1, 0x2, 0x3, 0x4, 0x5]);
    const json = JSON.stringify(buf);
    console.log(json)//{"type":"Buffer","data":[1,2,3,4,5]}

    拷贝缓冲区

    语法:

    buf.copy(targetBuffer[, targetStart[, sourceStart[, sourceEnd]]])

    targetBuffer - 必选参数,要拷贝的 Buffer 对象。

    targetStart - 数字, 可选, 默认: 0

    sourceStart - 数字, 可选, 默认: 0

    sourceEnd - 数字, 可选, 默认: buffer.length

    var buf1 = Buffer.from('ABCDEFGHIJKLMNOP');
    var buf2 = Buffer.from('UVWXYZ');
    //将 buf2 插入到 buf1 指定位置上
    buf2.copy(buf1, 2);
    console.log(buf1.toString());

    缓冲区与迭代器

    可以使用 for&hellip;of 语法迭代 Buffer 实例:

    通过迭代后会以十进制显示。

    const buf = Buffer.from([oxc,2,3,4,5]);
    console.log(buf)//<Buffer 01 02 03 04 05>
    
    for (const b of buf) {
        console.log(b);
    }
    //12
    // 2
    // 3
    // 4
    // 5
    const buf = Buffer.from('string');
    console.log(buf)//<Buffer 73 74 72 69 6e 67>
    
    for (const b of buf) {
        console.log(b);
    }
    //115
    // 116
    // 114
    // 105
    // 110
    // 103

    小结

    1、Buffer对象是Node处理二进制数据的一个接口。它是Node原生提供的全局对象,可以直接使用。

    2、网络层对于不同资源的请求和响应都是用二进制的形式来交互的。javascript中的字符串是以utf-8的格式存储的,处理二进制的能力很弱,因此需要使用Buffer来处理二进制数据。

    关于Node.js中的Buffer对象及创建方式是什么问题的解答就分享到这里了,希望以上内容可以对大家有一定的帮助,如果你还有很多疑惑没有解开,可以关注亿速云行业资讯频道了解更多相关知识。

    向AI问一下细节

    免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

    AI