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

//********注意***********
//slice()方法会返回一个新的buffer,但是新的bf2和源对象bf引用的是同一个!!!!也就是bf2的改变会改变bf
var bf=new Buffer('panwen');
console.log(bf);   //
var bf2=bf.slice(1,4);//---从下标1开始截取,截取到4,不包括4
console.log(bf2);
bf2[0]=0;
console.log(bf2);  //
console.log(bf);//
//********注意***********
要想实现深拷贝,用Buffer.copy(tembf);
var bf=new Buffer('panwen');
console.log(bf);   //
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);//后四位随机,不初始化

bf3[0]=0;
console.log(bf3);//
console.log(bf); //,不会改动原对象

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