学习总结

面试题总结MARK

1.什么是面向对象思想?

学习总结_第1张图片
664ba37eeee9f4623c06c066867f1d38_hd.jpg
把一组数据结构和处理它们的方法组成对象,把相同的行为归纳为类,通过类的封装隐藏内部细节,通过继承实现类的特化/泛化,通过多态实现基于对象类型的动态分派。

2._weak 对应的哈希表是用什么做key的?

http://www.swifty.cc/570.htm

实现原理

weak表其实就是一个hash表,key是所指对象的地址,value是weak指针的地址(这个地址的值是所指对象指针的地址)数组

1.初始化:runtime 会调用obj_initWeak函数,初始化一个新的weak指针指向对象的地址

2.添加引用:调用objc_storeWeak()函数,更新指针指向,创建对应的弱引用表

3.调用cleardeallocating函数,根据对象地址遍历获取指针地址数组,把其中的数据设为nil,然后把entry从weak表中移除,最后清理对象的记录

3.为什么可以给nil对象发送消息?

http://blog.csdn.net/jeffasd/article/details/51615151

PC上,在C语言中对空指针进行操作,程序会由于越界访问而出现保护错进而崩溃, 
OC 中需要从 objc_msgSend 的arm版汇编代码中找到答案
在arm的函数调用过程中,一般用r0~r4 传递参数,用r0传递返回值
id objc_msgSend(id self,SELop,...)
on entry : a1 is the message receiver, 消息接收者,即返回值也是self,都放在r0(a1)中
         : a2 is the selector
    
check whether receiver is nil 
teq   a1,#0
moveq a2,#0
bxeq  lr

teq  指令说明
TEQ 测试self 是否为空
moveeq  如果self为空,则将 seletor 也设置为空
bx 指令说明:bx lr 用来返回到调用子程序的地方即返回到调用者

如果传递给objc_msgSend 的self参数是 nil,该函数不会执行有意义的操作,直接返回
向nil 发送消息
    在OC中向nil发送消息是完全有效的,只是在运行时不会有任何作用
    . 若方法返回值是是一个对象,那么发送给nil的消息将返回0(nil);
    . 若方法返回值时指针类型,其指针大小为小于或等于sizeof(void*),float,double,long double,long long的变量,发送nil的消息将返回0;
    . 如果方法返回值为结构体,发送给nil的消息将返回0,结构体中各个字段的值将都是0
    . 如果方法的返回值不是上面的几种情况,那么发送给nil 的消息的返回值将是未定义的
https://www.zhihu.com/question/31022750
指针的主要功能:避免副本和共享数据  重要功能:函数之间传递参数 
  • nil:指向oc中对象的空指针
  • Nil:指向oc中类的空指针
  • NULL:指向其它类型的空指针,如一个C类型的空指针
  • NSNull:在集合对象中,表示空值的对象
  • [obj message] obj 为nil,将返回NO,obj 为 NSNull 将抛出异常NSException
  • NSNull 在集合中不能存放nil值,NSNull 只有一个方法:null
  • NSNotFound: 表示一个整型不存在,其实表示一个整型的最大值(NSIntegerMax)

4. IMP(Implemetion) SEL(selector) Method 的区别?

http://www.jianshu.com/p/84d1771e9792

SEL(selector): typedef struct objc_selector *SEL 选择子或选择器,代表方法在runtime期间的标识符,为SEL类型,虽然SEL是objc_selector结构体指针,但实际上只是一个C字符串。在类加载的时候编译器会生成与方法相对应的选择子,并注册到OC的runtime运行系统。
常见的两种创建/获取选择子:
SEL selA = @selector(setString:);
SEL selB = sel_registerName("setString");
selA selB 指向相同的地址,代表同一个字符串

const char *sel_getName(SEL sel){
    return sel ? (const char *)sel : "";
}
从上面可以看出SEL 和 const char * 是可以相互转化的

Implementation(IMP):
typedef id (*IMP)(id,SEL,...)
代表函数指针,即函数执行的入口
第一个参数指向self(代表当前类实例的地址,如果是类则指向的是它的元类),作为消息的接收者
第二个参数代表的方法的选择子;... 代表可选参数,前面的id代表返回值

Method
typedef struct objc_method *Method
Method 是一个objc_method 结构体指针

struct objc_method {
 SEL method_name; SEL是obj_selector结构体指针,实际上它是一个C字符串,相同的方法即使是在不同的类中定义,它们的方法选择器也相同
 char *method_types; char 指针 存储着方法的参数类型和返回值类型,即是type Encoding 编码
 IMP method_imp; 函数指针,即函数执行的入口
}

一个类持有一个分发表,在运行期分发消息,表中每一个实体代表一个方法(Method),它的名字叫做选择子(SEL),对应着一种方法实现(IMP)。

5.VC的生命周期?

  • (void)load;
  • (void)initialized;

xib/stroyboard

  • (void)awakeFromNib; 需要写一个UIView的子类并且想在load nib的时候做一些初始化的工作,bundle在load nib的后会给每个view对象法一个awakeFromNib消息

非xib/stroyboard

  • (instancetype)init; //初始化
  • (instancetype)initWithFrame:(CGRect)frame;
  • (instancetype)initWithCoder:(NSCoder *)aDecoder;

公用

  • (void)loadView; 初始化view,view为nil时调用,首先去查找xib文件来创建view,没有的话就创建一个空白的view
  • (void)viewDidLoad; 界面的初始化操作,例如添加子控件和获取网络数据
  • (void)viewWillAppear:(BOOL)animated; //view load完成后将要出现在屏幕之前会调用这个方法
  • (void)viewDidAppear:(BOOL)animated; //当view已经在屏幕上显示出来之后,会调用这个方法
  • (void)viewWillDisAppear:(BOOL)animated; //当视图将要从屏幕上移除时候调用
  • (void)viewWillDidDisAppear:(BOOL)animated; //当视图已经从屏幕上移除时候调用
  • (void)dealloc;//dealloc方法不能由我们主动调用,必须等引用计数为0时候由系统调用

cell相关

/*
// if the cell is reusable (has a reuse identifier),
// this is called just before the cell is returned from the table view method dequeueReusableCellWithIdentifier:.
// If you override, you MUST call super.
//防止图片错乱,把内容清空掉
*/

  • (void)prepareForReuse;

你可能感兴趣的:(学习总结)