对mrc和arc的理解
ARC全称是 Automatic Reference Counting,是Objective-C的内存管理机制。简单地来说,就是代码中自动加入了retain/release,原先需要手动添加的用来处理内存管理的引用计数的代码可以自动地由编译器完成了。 ARC的使用是为了解决对象retain和release匹配的问题。以前手动管理造成内存泄漏或者重复释放的问题将不复存在。 以前需要手动的通过retain去为对象获取内存,并用release释放内存。所以以前的操作称为MRC (Manual Reference Counting)。
谈谈对自动释放池的理解
自动释放池在mrc和arc区别
多层自动释放池嵌套的对象在哪一层释放
对于block,理解,mrc和arc下有什么区别,使用注意事项
对于深拷贝和浅拷贝的理解
请说明并比较以下关键词:strong, weak, assign, copy
- strong表示指向并拥有该对象。其修饰的对象引用计数会增加1。该对象只要引用计数不为0则不会被销毁。当然强行将其设为nil可以销毁它。
- weak表示指向但不拥有该对象。其修饰的对象引用计数不会增加。无需手动设置,该对象会自行在内存中销毁。
- assign主要用于修饰基本数据类型,如NSInteger和CGFloat,这些数值主要存在于栈上。
- weak 一般用来修饰对象,assign一般用来修饰基本数据类型。原因是assign修饰的对象被释放后,指针的地址依然存在,造成野指针,在堆上容易造成崩溃。而栈上的内存系统会自动处理,不会造成野指针。
- copy与strong类似。不同之处是strong的复制是多个指针指向同一个地址,而copy的复制每次会在内存中拷贝一份对象,指针指向不同地址。copy一般用在修饰有可变对应类型的不可变对象上,如NSString, NSArray, NSDictionary。
- Objective-C 中,基本数据类型的默认关键字是atomic, readwrite, assign;普通属性的默认关键字是atomic, readwrite, strong。
请说明并比较以下关键词:__weak,__block
- __weak与weak基本相同。前者用于修饰变量(variable),后者用于修饰属性(property)。__weak 主要用于防止block中的循环引用。
- __block也用于修饰变量。它是引用修饰,所以其修饰的值是动态变化的,即可以被重新赋值的。__block用于修饰某些block内部将要修改的外部变量。
- __weak和__block的使用场景几乎与block息息相关。而所谓block,就是Objective-C对于闭包的实现。闭包就是没有名字的函数,或者理解为指向函数的指针。
请说明并比较以下关键词:atomatic, nonatomic
- atomic修饰的对象会保证setter和getter的完整性,任何线程对其访问都可以得到一个完整的初始化后的对象。因为要保证操作完成,所以速度慢。它比nonatomic安全,但也并不是绝对的线程安全,例如多个线程同时调用set和get就会导致获得的对象值不一样。绝对的线程安全就要用关键词synchronized。
- nonatomic修饰的对象不保证setter和getter的完整性,所以多个线程对它进行访问,它可能会返回未初始化的对象。正因为如此,它比atomic快,但也是线程不安全的。
weak原理
如果属性完全不加修饰词入weak,atomic,系统会怎么处理
简述下block的实现
Http协议30x的错误是什么
谈谈你懂runloop得理解:由浅入深
https://blog.ibireme.com/2015/05/18/runloop/
谈谈对多线程理解:由浅入深
http://xuyafei.cn/post/draft/ios-thread
谈谈category和extension区别,系统如何底层实现category
谈谈消息转发机制实现
谈谈事件响应链,如何响应view之外的事件
界面性能优化
事件传递
https://www.jianshu.com/p/2e074db792ba
组件化
https://blog.cnbang.net/tech/3080/
以scheduledTimerWithTimeInterval的方式触发的timer,在滑动页面上的列表时,timer会暂停,为什么?该如何解决?
-
原因在于滑动时当前线程的runloop切换了mode用于列表滑动,导致timer暂停。
-
runloop中的mode主要用来指定事件在runloop中的优先级,有以下几种:
-
Default(NSDefaultRunLoopMode):默认,一般情况下使用;
-
Connection(NSConnectionReplyMode):一般系统用来处理NSConnection相关事件,开发者一般用不到;
-
Modal(NSModalPanelRunLoopMode):处理modal panels事件;
-
Event Tracking(NSEventTrackingRunLoopMode):用于处理拖拽和用户交互的模式。
-
Common(NSRunloopCommonModes):模式合集。默认包括Default,Modal,Event Tracking三大模式,可以处理几乎所有事件。
-
回到题中的情境。滑动列表时,runloop的mode由原来的Default模式切换到了Event Tracking模式,timer原来好好的运行在Default模式中,被关闭后自然就停止工作了。
-
解决方法其一是将timer加入到NSRunloopCommonModes中。其二是将timer放到另一个线程中,然后开启另一个线程的runloop,这样可以保证与主线程互不干扰,而现在主线程正在处理页面滑动。示例代码如下:
// 方法1
[[NSRunLoop currentRunLoop] addTimer:timer forMode:NSRunLoopCommonModes];
// 方法2
dispatch_async(dispatch_get_global_queue(0, 0), ^{
timer = [NSTimer scheduledTimerWithTimeInterval:1 target:self selector:@selector(repeat:) userInfo:nil repeats:true];
[[NSRunLoop currentRunLoop] run];
});
KVO、Notification、delegate 各自的优缺点,效率还有使用场景
如何手动通知 KVO
Objective-C 中的 copy 方法
runtime 中,SEL 和 IMP 的区别
autoreleasepool 的使用场景和原理
RunLoop 的实现原理和数据结构,什么时候会用到
block 为什么会有循环引用
使用 GCD 如何实现这个需求:A、B、C 三个任务并发,完成后执行任务 D。
NSOperation 和 GCD 的区别
CoreData 的使用,如何处理多线程问题
如何设计图片缓存?