问题

1.  Notification和KVO有什么不同?KVO在ObjC中是怎么实现的?

KVO:只能监听属性值的变化,而且有一定的弊端;

在别处修改了属性,也会调用KVO的方法,可能会造成数据错乱

当给一个对象添加监听后,会生成这个类的子类.NSKvoNotifying,并重写被监听属性的set方法;在开发中如果创建了同名的类,会报错

使用Objective-C  强大的runtime功能实现了这个功能。属性类class中并没有实现KVO通知的相关方案,而是在调用addObserver之后定义属性类的子类subclass,subclass里边实现了属性的setter方法,setter方法中实现发动通知的功能。然后subclass中实现class函数,还让返回属性类的class,再让属性类对象的isa指向subclass,这样就伪装成表面上看还是属性类自己实现的通知功能。通过原理我们可以看出 必须使用属性方法或者setValue:forKey方法赋值才会发送通知,直接赋值是不会收到通知的.


2. UIViewController类中didReceiveMemoryWarning默认的操作是什么?

当程序接到内存警告时View Controller将会收到这个消息:didReceiveMemoryWarning

从iOS3.0开始,不需要重载这个函数,把释放内存的代码放到viewDidUnload中去。

这个函数的默认实现是:检查controller是否可以安全地释放它的view(这里view指的是controller的view属性),比如view本身没有superview并且可以被很容易地重建(从nib或者loadView函数)。

如果view可以被释放,那么这个函数释放view并调用viewDidUnload。

你可以重载这个函数来释放controller中使用的其他内存。但要记得调用这个函数的super实现来允许父类(一般是UIVIewController)释放view。

如果你的ViewController保存着view的子view的引用,那么,在早期的iOS版本中,你应该在这个函数中来释放这些引用。而在iOS3.0或更高版本中,你应该在viewDidUnload中释放这些引用。


3. 存放数字用什么类型?存放CGRect用什么类?

NSNumber存放数字,NSValue可以存放CGrect


4. 简述HTTP通信中的阻塞与非阻塞方式

阻塞模式和非阻塞模式的主要区别在于无请求来到时,阻塞模式会一直停在接收函数即accep函数,直到有请求到来才会继续向下进行处理。

而非阻塞模式下,运行接收函数,如果有请求,则会接收请求,如果无请求,会返回一个负值,并继续向下运行。一般来说,使用阻塞模式

的程序比较多,因为阻塞模式是由内核保障等待请求的,当他阻塞时不占用系统资源,而非阻塞模式需要我们人工轮询,占用资源较多。

另外,阻塞模式可以使用select函数设置超时时间,具体可以参考相关书籍。


5. HTTP报文中Content-type有和作用

在Http协议消息头中,使用Content-Type来表示具体请求中的媒体类型信息


6. NSTimer是否是多线程的?使用时是否要加同步锁?

不是,只能加到RunLoop中特定模式下才能工作;不需要,因为它只在单一线程工作

九. main函数执行之前和执行之后,有可能分别会执行什么代码

全局对象的构造函数会在main 函数之前执行,

全局对象的析构函数会在main函数之后执行;

用atexit注册的函数也会在main之后执行。

一些全局变量、对象和静态变量、对象的空间分配和赋初值就是在执行main函数之前,而main函数执行完后,还要去执行一些诸如释放空间、释放资源使用权等操作

进程启动后,要执行一些初始化代码(如设置环境变量等),然后跳转到main执行。全局对象的构造也在main之前。


7. 父类未实现的delegate是否可以由子类实现

可以,父类遵守的协议,子类也会继承这个协议

你可能感兴趣的:(问题)