博客
关于我
OC--Id和构造方法
阅读量:608 次
发布时间:2019-03-12

本文共 670 字,大约阅读时间需要 2 分钟。

* id是指万能指针,能指向\操纵任何OC对象;*

注意:写id的时候不要写*;

局限性:调用一个不存在的方法,编译器会马上报错!

例如:

Person *p = [Person new];NSObject *n= [Person new];Id d = [Person new];

构造方法

完整的创建一个可用对象分为两步:

1>分配存储空间 +alloc

2>初始化 -init

New方法是创建一个对象的方法,[Person new]是一个类方法。

构造方法的用途是用来初始化对象的方法,是一个以“-”开头的对象方法(默认初始化完了之后的值都是0)

Person *p = [[Person alloc] init];

例题:

每个Person对象创建出来,它的age都是10.

重写init构造方法条件

1> 一定要调用回super的init方法:初始化父类中声明的一些成员变量和其他属性。

2>如果对象初始化成功,才有必要进行下来的初始化

3> 然后返回初始化的数值

代码演示:

这里写图片描述
运行结果如下
这里写图片描述

构造方法的注意点:

1> 先调用父类的构造方法([super init])

2> 在进行子类内部成员变量的初始化

自定义构造方法:

1 、命名规范

1> 一定是对象方法,一定以“-”开头

2> 返回值一般是id类型

3> 方法名一般以init开头

2 、 自定义构造方法的用途:初始化值

1> 当父类中的成员变量存在,我们仅仅需要直接将需要初始化的值直接传到父类中初始化即可

2> 父类的属性给父类方法处理,子类仅需要处理自己的属性即可

你可能感兴趣的文章
MySQL 树形结构 根据指定节点 获取其下属的所有子节点(包含路径上的枝干节点和叶子节点)...
查看>>
mysql 死锁 Deadlock found when trying to get lock; try restarting transaction
查看>>
mysql 死锁(先delete 后insert)日志分析
查看>>
MySQL 死锁了,怎么办?
查看>>
MySQL 深度分页性能急剧下降,该如何优化?
查看>>
MySQL 深度分页性能急剧下降,该如何优化?
查看>>
MySQL 添加列,修改列,删除列
查看>>
mysql 添加索引
查看>>
MySQL 添加索引,删除索引及其用法
查看>>
mysql 状态检查,备份,修复
查看>>
MySQL 用 limit 为什么会影响性能?
查看>>
MySQL 用 limit 为什么会影响性能?有什么优化方案?
查看>>
MySQL 用户权限管理:授权、撤销、密码更新和用户删除(图文解析)
查看>>
mysql 用户管理和权限设置
查看>>
MySQL 的 varchar 水真的太深了!
查看>>
mysql 的GROUP_CONCAT函数的使用(group_by 如何显示分组之前的数据)
查看>>
MySQL 的instr函数
查看>>
MySQL 的mysql_secure_installation安全脚本执行过程介绍
查看>>
MySQL 的Rename Table语句
查看>>
MySQL 的全局锁、表锁和行锁
查看>>