您的位置:首页 > 其它

关于OC的一些理论知识

2014-08-30 23:38 162 查看

关于OC的一些理论知识

1.开放/关闭原则

软件实体应该对扩展开放,而对修改关闭

2.

面向对象、数据第一、函数第二

数据为中心,函数为数据服务

面向过程、函数第一、数据第二

3.继承

oc 使用类别和协议 实现多继承,效果是一样的

当前类没有相应方法,则会在超类(父类)中搜索

4. 复合

oc ,复合是通过包含作为实力变量的对象指针实现的。

继承,对象间简历 is a 的关系,“是”一个

复合,has a ,“有‘一个的关系

严格的讲只有对象间的组合才叫复合。

5. self

每个方法调用都或得一个self的隐藏参数,指向接收消息的对象的指针。

方法使用self参数查找要使用的实例变量

6. new

完成两个工作,分配内内存,或得一个用来存放实例变量的内存块。

调用init方法,使对象处于可用状态。

7.%@

只是调用每个对象的 description 方法并显示结果。

description,可以把。。转换成对象;

比如输出一个 array 里面的对象之类的。

8. get / set 方法

get 意味着,会通过你当做参数传入的指针来返回数据

所以命名的时候,如果使用get,一般有经验人会认为要使用指针作为参数传入这个方法。

9.self.XXX = nil

self.对象 = nil 效果就不一样了

等同于

if(对象 != nil) {

[对象release];

对象= nil;

}

再来细说一下, 个人认为 [对象 release] 后这个对象就没有指向任何内存空间了

,这个时候,它是不能被使用的(可以试试 NSLog一下 release 后的对象,有惊喜的。。。)

当 对象 = nil 时,这个对象是指向了一个内存空间的(好像是 0x0000..... 什么的),

这个时候这个对象是可以被NSLog出来的。。。。。

10.关于@class XXXX 和 #import “XXXX.h”

在复合关系中,@class 创建了一个向前引导,告诉编译,现在只需要知道有一个类,而不需要知道这个类是什么。

在循环依赖中尤为重要,就是A包含B,B也包含A,则使用@class,使用import会报错。

@class一般是,只是指针使用类里的变量,就这么声明会更好。

继承关系之间则不能使用@class

@class second; 只是声明了一下second类,只有在本代码文件中不用申请second对象时才能这样用。

而#import "Second.h"是将second的类定义文件包含进来了。

---------------------------------------------------------------------------------------------

这时有两个选择,一是import这两个被引用类的头文件,另一个是使用@class申明Woman和Man是类名,

二者的区别:

1. import会包含这个类的所有信息,包括实体变量和方法,

而@class只是告诉编译器,其后面声明的名称是类的名称,至于这些类是如何定义的,暂时不用考虑,后面会再告诉你;

2. 在头文件中,一般只需要知道被引用的类的名称就可以了,不需要知道其内部的实体变量和方法,

所以在头文件中一般使用@class来声明这个名称是类的名称,

而在类的实现部分,因为会用到这个引用类的内部的实体变量和方法,所以需要使用#import来包含这个被引用类的头文件。

3. 在编译效率方面考虑,如果你有100个头文件都#import了同一个头文件,或者这些文件是依次被引用的,

如A–>B,B–>C,C–>D这样的引用关系。当最开始的那个头文件有变化的话,后面所有引用它的类都需要重新编译

,如果你的类有很多的话,这将耗费大量的时间。而是用@class则不会。

4.如果有循环依赖关系,如:A–>B,B–>A这样的相互依赖关系,如果使用#import来相互包含,那么就会出现编译错误,

如果使用@class在两个类的头文件中相互声明,则不会有编译错误出现。

所以,一般来说,@class是放在interface中的,只是为了在interface中引用这个类,把这个类作为一个类型来用的。

在实现这个接口的实现类中,如果需要引用这个类的实体变量或者方法之类的,还是需要import在@class中声明的类进来.
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: