博客
关于我
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学习总结(71)——数据库介绍(MySQL安装 体系结构、基本管理)再回顾
查看>>
Mysql学习总结(72)——MySQL 开发者开发,设计规范再总结
查看>>
Mysql学习总结(73)——MySQL 查询A表存在B表不存在的数据SQL总结
查看>>
Mysql学习总结(74)——慢SQL!压垮团队的最后一根稻草!
查看>>
Mysql学习总结(75)——并发量大、数据量大的互联网业务数据库设计军规
查看>>
Mysql学习总结(76)——MySQL执行计划(explain)结果含义总结
查看>>
Mysql学习总结(77)——温故Mysql数据库开发核心原则与规范
查看>>
Mysql学习总结(78)——MySQL各版本差异整理
查看>>
Mysql学习总结(79)——MySQL常用函数总结
查看>>
Mysql学习总结(7)——MySql索引原理与使用大全
查看>>
Mysql学习总结(80)——统计数据库的总记录数和库中各个表的数据量
查看>>
Mysql学习总结(81)——为什么MySQL不推荐使用uuid或者雪花id作为主键?
查看>>
Mysql学习总结(82)——MySQL逻辑删除与数据库唯一性约束如何解决?
查看>>
Mysql学习总结(83)——常用的几种分布式锁:ZK分布式锁、Redis分布式锁、数据库分布式锁、基于JDK的分布式锁方案对比总结
查看>>
Mysql学习总结(84)—— Mysql的主从复制延迟问题总结
查看>>
Mysql学习总结(85)——开发人员最应该明白的数据库设计原则
查看>>
Mysql学习总结(8)——MySql基本查询、连接查询、子查询、正则表达查询讲解
查看>>
Mysql学习总结(9)——MySql视图原理讲解与使用大全
查看>>
Mysql学习笔记 - 在Centos7环境下离线安装Mysql
查看>>
MySQL学习笔记十七:复制特性
查看>>