您的位置:首页 > Web前端

buffer的slice()方法返回的新buffer和原buffer引用的是同一个对象!!!修改千万要注意!

2017-04-26 20:27 351 查看
//********注意***********
//slice()方法会返回一个新的buffer,但是新的bf2和源对象bf引用的是同一个!!!!也就是bf2的改变会改变bf
var bf=new Buffer('panwen');
console.log(bf);   //<Buffer 70 61 6e 77 65 6e>
var bf2=bf.slice(1,4);//<Buffer 61 6e 77>---从下标1开始截取,截取到4,不包括4
console.log(bf2);
bf2[0]=0;
console.log(bf2);  //<Buffer 00 6e 77>
console.log(bf);//<Buffer 70 00 6e 77 65 6e>
//********注意***********

要想实现深拷贝,用Buffer.copy(tembf);

var bf=new Buffer('panwen');
console.log(bf);   //<Buffer 70 61 6e 77 65 6e>
var bf3=new Buffer(10);
//var bf3=bf.copy();不是这么写!,是下面的写法//**************实现深拷贝!!*************
bf.copy(bf3);//这是拷贝到bf3中!,拷贝也可选位置,bf.copy(bf3,1,2,4)从第二位开始拷贝到3,1实质拷贝到buffer的第一位!
console.log(bf3);//<Buffer 70 61 6e 77 65 6e 6f 72 00 00>后四位随机,不初始化

bf3[0]=0;
console.log(bf3);//<Buffer 00 61 6e 77 65 6e 6f 72 00 00>
console.log(bf); //<Buffer 70 61 6e 77 65 6e>,不会改动原对象
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: 
相关文章推荐