我是前端小白一枚,为了巩固知识和增强记忆,开始整理相关的知识,方便以后复习和面试的时候看看.OK,让我们进入正题~ 先说说浅拷贝和深拷贝的理解吧,个人是这样理解的:两个对象A.B, A有数据B为空,B复制了A,我们修改A,如果B中的数据跟着变化了,那就是浅拷贝,如果没有变化,那就是深拷贝.说明B另开辟了一块内存(下文会讲解). 举个栗子: AB两个对象,我只改变了A中的元素,为什么B中的元素也跟着变化了?(上面是一个浅拷贝的栗子) 要深入理解浅拷贝和深拷贝的原理,那就要涉及到一些基本数据类型和引…
深拷贝与浅拷贝(mutableCopy与Copy)详解 iOS ios中并不是所有的对象都支持copy,mutableCopy,遵守NSCopying 协议的类可以发送copy消息,遵守NSMutableCopying 协议的类才可以发送mutableCopy消息.假如发送了一个没有遵守上诉两协议而发送 copy或者 mutableCopy,那么就会发生异常.但是默认的ios类并没有遵守这两个协议.如果想自定义一下copy 那么就必须遵守NSCopying,并且实现 copyWithZone:…
1. 对于基本数据类型 其值在内存中占据着固定大小的空间,并被保存在栈内存中.当一个变量向另一个变量复制基本类型的值,会创建这个值的副本,并且我们不能给基本数据类型的值添加属性.其为深拷贝. 2. 对于引用类型  浅拷贝:只复制指向某个对象的指针,而不复制对象本身,新旧对象共享一块内存: 改变一个对象,另一个会随之改变: 深拷贝:复制并创建一个一模一样的对象,不共享内存,修改新对象,旧对象保持不变. 01 浅拷贝的实现 var arr = [1, 2, 3, '4']; var arr2 = a…
copy与retain的区别: copy是创建一个新对象,retain是创建一个指针,引用对象计数加1.Copy属性表示两个对象内容相同,新的对象retain为1 ,与旧有对象的引用计数无关,旧有对象没有变化.copy减少对象对上下文的依赖. retain属性表示两个对象地址相同(建立一个指针,指针拷贝),内容当然相同,这个对象的retain值+1也就是说,retain 是指针拷贝,copy 是内容拷贝. 当然在ios中并不是所有的对象都支持copy,mutableCopy,遵守NSCopyin…
最近在前端开发中遇到一些问题,就是数组中的某个对象或某个对象的值改变之后,在不刷新页面的时候需要重新渲染值时,页面显示的还是原来的数据.比如: data{ A:[{id:1,num:1},{id:2,num:2},{id:3,num:3}] } function changeA(){ let B = this.data.B; B[1].num = 88 this.setData({ A:B }); console(this.data.A); } 这时候打印出来时已经改变的值.A:[{id:1,n…
js 深拷贝和浅拷贝 先举一下项目中遇到的两个例子: 例子1: var json = $.parseJSON(data.data);//data.data是接口返回的值var a = json.channels;var b = json.channels;console.log(a === b);//true 这个例子是浅拷贝,a.b两个对象是完全相等的,指向的内存地址也是一样的,a和b会互相影响,当b对象改变时,a也会跟着改变. 在项目中就吃了这个亏,a对象本来想要存一个原始值,b是一个在原始…
前言 经常会在一些网站或博客看到"深克隆","浅克隆"这两个名词,其实这个很好理解,今天我们就在这里分析一下js深拷贝和浅拷贝. 浅拷贝 我们先以一个例子来说明js浅拷贝: var n = {a: 1, b: 2} var m = n m.a = 12 console.log(n.a) // ? 上面显然 n.a 的值会变为 12,这就是js浅拷贝.浅拷贝只是拷贝的指向对象的指针,本质上还是指向同一个对象. 深拷贝 同样我们还是以一个例子来说明啥叫 js deep…
python的复制,深拷贝和浅拷贝的区别    在python中,对象赋值实际上是对象的引用.当创建一个对象,然后把它赋给另一个变量的时候,python并没有拷贝这个对象,而只是拷贝了这个对象的引用    一般有三种方法,        alist=[1,2,3,["a","b"]]    (1)直接赋值,传递对象的引用而已,原始列表改变,被赋值的b也会做相同的改变        >>> b=alist        >>> pr…
vue.js选择if(条件渲染)详解 一.总结 一句话总结: v-if <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>v-if</title> <link rel="stylesheet" type="text/css" href="css/sty…
vue.js循环for(列表渲染)详解 一.总结 一句话总结: v-for <ul id="example-1"> <li v-for="item in items"> {{ item.message }} </li> </ul> var example1 = new Vue({ el: '#example-1', data: { items: [ { message: 'Foo' }, { message: 'Bar…