ViewController.h

#import <UIKit/UIKit.h>

@interface ViewController : UIViewController

//如果想让list成为一个可变的数组,需要把copy变成retain,因为copy之后的对象永远都只是一个不可变的对象

@property (nonatomic,copy)NSMutableArray *list;

@end

ViewController.m

/*

拷贝:复制一个对象->变成另外一个对象

深拷贝:复制对象并且复制对象里面的内容,完全拷贝

浅拷贝:指针拷贝,只拷贝对象本身,不拷贝里面的内容

看是不是深拷贝,主要看是不是拷贝了对象里面的内容

系统自带的拷贝都是浅拷贝,eg:copy、mutableCopy

实现深拷贝的方式:

1、自定义拷贝(要看具体拷贝内容的实现)

2、系统提供给了深拷贝的方法

(1)数组:- (instancetype)initWithArray:(NSArray<ObjectType> *)array copyItems:(BOOL)flag

(2)字典:- (instancetype)initWithDictionary:(NSDictionary<KeyType, ObjectType> *)otherDictionary copyItems:(BOOL)flag

自定义拷贝:

1、copyWithZone:

2、mutableCopyWithZone:

并不是所有对象都可以拷贝 ->只有遵守了拷贝协议的对象才可拷贝

mutableCopy:?深浅拷贝

指针拷贝 ->浅拷贝

对象拷贝 ->深拷贝

mutableCopy ->深拷贝

在使用mutableCopy 拷贝后两个对象的内存地址是不一样的

拷贝对象的内容 的内存地址是否发生改变 ->mutableCopy属于浅拷贝

*/

#import "ViewController.h"

#import "UserInfoModel.h"

@interface ViewController ()

@end

@implementation ViewController

- (void)viewDidLoad {

[super viewDidLoad];

UserInfoModel *red = [[UserInfoModel alloc]init];

UserInfoModel *yellow = [[UserInfoModel alloc]init];

UserInfoModel *blue = [[UserInfoModel alloc]init];

NSArray *colorList = @[red,yellow,blue];

NSLog(@"拷贝前%p",colorList[0]);

//copyItems 如果设置的是YES就是深拷贝

//    NSArray *newList = [[NSArray alloc]initWithArray:colorList copyItems:YES];

NSArray *newList = [colorList mutableCopy];

NSLog(@"拷贝后%p",newList[0]);

//    [red copy];

red.list = [NSMutableArray arrayWithObjects:@"1", nil];

[red.list  addObject:@"2"];

UserInfoModel *new = [red mutableCopy];

[new.list addObject:@"3"];

/*

copy :拷贝之后的对象是不可变的对象

mutableCopy:拷贝之后的对象是可变的对象,但是必须用对应的类型去接收

*/

//NSArray *list = @[];

//    NSMutableArray *newList = [list mutableCopy];

//要想把拷贝之后的对象变成可变的必须用可变的数据类型去接收

//    NSArray *newList = [list mutableCopy];

//    [newList addObject:@"1"];

/*

**************************************************************

*

*不可变对象 copy ->不可变对象 ->不管用可变或者不可变类型接收 都是不可变

*可变对象 copy ->不可变对象 ->不管用可变或者不可变类型接收 都是不可变

*

*不可变对象 mutableCopy -> 可变对象 ->不可变对象接收 -> 不可变对象

*不可变对象 mutableCopy -> 可变对象 ->可变对象接收 -> 可变对象

*可变对象   mutableCopy -> 可变对象 ->不可变对象接收 -> 不可变对象

*可变对象 mutableCopy -> 可变对象 ->可变对象接收 -> 可变对象

*

**************************************************************

*总结:(1)只要使用copy就是不可变对象

@property (nonatomic,copy)NSMutableArray *list;

在声明可变数组的属性的时候,只要使用copy这个关键字就会变成不可变的数组

原因:在setter方法的实现中全部使用了copy

(2)使用mutableCopy必须使用可变类型接收,才是可变对象

自定义拷贝:

并不是所有类型 都可以拷贝 ->如果想让不可以拷贝的类型实现拷贝 ->自定义拷贝

可以拷贝的数据类型:nsstring nsarray nsdictionary

自定义拷贝的步骤:

1、导入拷贝协议

2、实现协议的方法

(1)copyWithZone:

(2)mutableCopyWithZone:

*/

//不管用什么数据类型接收copy之后的内容,都是一个不可变的对象

//    NSArray *list1 = @[];

//    NSMutableArray *new1 = [list1 copy];

//    [new1 addObject:@"1"];                会奔溃

}

- (void)didReceiveMemoryWarning {

[super didReceiveMemoryWarning];

// Dispose of any resources that can be recreated.

}

@end

UserInfoModel.h

#import <Foundation/Foundation.h>

//1、遵守拷贝协议

@interface UserInfoModel : NSObject<NSCopying,NSMutableCopying>

@property(nonatomic,retain)NSMutableArray *list;

@property(nonatomic,retain)NSMutableDictionary *info;

@end

UserInfoModel.m

#import "UserInfoModel.h"

@implementation UserInfoModel

- (id)copyWithZone:(nullable NSZone *)zone

{

//allocWithZone: 是在执行cop的时候分配内存

UserInfoModel *new = [[UserInfoModel allocWithZone:zone]init];

//new是拷贝之后的新的对象

new.list = [self.list copy];

new.info = [self.info copy];

return new;

}

- (id)mutableCopyWithZone:(nullable NSZone *)zone

{

UserInfoModel *new = [[UserInfoModel allocWithZone:zone]init];

new.list = [self.list mutableCopy];

new.info = [self.info mutableCopy];

return new;

}

@end

深浅拷贝的应用-copy、mutableCopy的更多相关文章

  1. copy之深浅拷贝

    深浅拷贝深拷贝 全部复制浅拷贝 只复制第一层 __author__ = 'Perfect' # -*- coding: utf-8 -*- import copy # copy.copy() #浅拷贝 ...

  2. Python 从零学起(纯基础) 笔记 之 深浅拷贝

    深浅拷贝 1. import  copy#浅拷贝copy.copy()#深拷贝copy.deepcopy()#赋值 = 2.   对于数字和字符串而言,赋值.浅拷贝和深拷贝无意义,因为其永远指向同一个 ...

  3. Python之深浅拷贝&函数

    一.深浅拷贝 深浅拷贝是指copy模块下的copy()和deepcopy()方法. 1.浅拷贝 示例: >>> import copy >>> a = 'hello ...

  4. python高级-深浅拷贝(16)

    一.浅拷贝 浅拷贝是对一个对象的顶层拷贝,通俗地讲就是:拷贝了引用,并没有拷贝内容. a = [1,2,3] print(id(a)) b=a print(b) print(id(b)) a.appe ...

  5. python之路(三)-深浅拷贝

    深浅拷贝用法来自copy模块. 导入模块:import copy 浅拷贝:copy.copy 深拷贝:deepcopy 字面理解:浅拷贝指仅仅拷贝数据集合的第一层数据,深拷贝指拷贝数据集合的所有层.所 ...

  6. 24、简述Python的深浅拷贝以及应用场景

    深浅拷贝的原理 深浅拷贝用法来自copy模块. 导入模块:import copy 浅拷贝:copy.copy 深拷贝:copy.deepcopy 字面理解:浅拷贝指仅仅拷贝数据集合的第一层数据,深拷贝 ...

  7. 简述Python的深浅拷贝以及应用场景

    深浅拷贝的原理 深浅拷贝用法来自copy模块. 导入模块:import copy 浅拷贝:copy.copy 深拷贝:copy.deepcopy 字面理解:浅拷贝指仅仅拷贝数据集合的第一层数据,深拷贝 ...

  8. Python:深浅拷贝

    导入模块: >>> import copy 深浅拷贝: >>> X = copy.copy(Y) #浅拷贝:只拷贝顶级的对象,或者说:父级对象 >>&g ...

  9. Python基础:深浅拷贝

    对于数字.字符串深浅拷贝: import copy num = 0 copy_num = copy.copy(num) print("These are normal copy") ...

随机推荐

  1. C#中类的修饰符

    Q&A  项目=程序集=assembly 1,Q:类的修饰符有哪些? A:   有 new.public.protect.internal.private.abstract.sealed.st ...

  2. requeests模块响应体属性和方法重新整理

    下面的属性方法都是基于response对象` import requests response = requests.get('url') 一.url 返回值的url 二. text 获得响应体文本信 ...

  3. linux中网络配置

    一.查看ip ipconfig 二.png 测试主机之间网络连通 ping 目标ip #测试当前服务器是否可以连接目的主机 三.linux配置网络环境 vim /etc/sysconfig/netwo ...

  4. GO-&获取地址与*解引用

    &变量 获取变量在内存空间的地址 *变量地址 获取变量的值 一.普通数据 package main import "fmt" func main(){ b :=1111 c ...

  5. JPA的基本注解

    场景 JPA入门简介与搭建HelloWorld(附代码下载): https://blog.csdn.net/BADAO_LIUMANG_QIZHI/article/details/103473937 ...

  6. PDF转换成DXF文件?PDF转DXF的操作方法

    在CAD工作中,经常就需要将绘制完成的图纸文件的格式进行转换,那怎么将PDF文件转换成DXF格式的呢?具体要怎么来进行操作呢?本编教程小编就来教教大家具体操作方法,具体操作如下: 一.工具转换 推荐指 ...

  7. ABP入门教程10 - 展示层实现增删改查-控制器

    点这里进入ABP入门教程目录 创建控制器 在展示层(即JD.CRS.Web.Mvc)的Controllers下新建一个控制器CourseController.cs using Abp.Applicat ...

  8. “强大”的MapPPP

    写在前面 因为要给用户发送通知提醒,项目中有个短信模板/微信模板/钉钉模板/邮件模板的占位符替换的class.其中一段代码的逻辑是根据入参(model/json)来定义要替换的占位符集合,使用的是Ma ...

  9. RDIFramework.NET敏捷开发框架 ━ 工作流程组件介绍

    RDIFramework.NET,基于.NET的快速信息化系统敏捷开发.整合框架,给用户和开发者最佳的.Net框架部署方案. 1.RDIFramework.NET敏捷开发框架介绍 RDIFramewo ...

  10. nginx 七层负载均衡

    [tcp] nginx 七层负载均衡 nginx负载均衡概述 当我们的Web服务器直接面向用户,往往要承载大量并发请求,单台服务器难以负荷,我使用多台Web服务器组成集群,前端使用Nginx负载均衡, ...