进军BAT复习计划一

作者: MichealXXX | 来源:发表于2018-10-04 12:57 被阅读99次
    25岁,从事iOS开发三年,先从微型创业公司干了一年,然后进入了一家大型非互联网企业从事iOS开发两年,是时候向自己的梦想进发,下面列出复习计划。
    复习要点:算法,操作系统,iOS基础,网络,数据结构。
    复习书籍:《剑指offer》 《程序员的自我修养》《图解HTTP》 《图解TCP/IP》 《OC高级编程》 《Effective OC 2.0》 《OC设计模式》
    iOS复习要点:runloop,runtime,autorelease,block,KVO,GCD,事件传递链,渲染,动画,网络安全,git问题。
    复习文章:

    runloop
    iOS中的多线程技术
    组件化
    事件传递
    sunny面试题
    peak面试题
    启动优化
    性能检测
    git知识
    bestwisher文章
    检测内存泄露
    KVO与KVC原理KVO、Notification、Delegate优缺点最推荐的官方文档
    GCD 与 NSOperation
    Runtime
    block
    atomic 线程安全@synchronized
    对象的深浅复制
    招聘一个靠谱的iOS
    消息传递机制
    深入理解Objective-C:Category
    RunLoop
    Cell 图片异步加载优化
    iOS 函数式编程的实现 && 响应式编程概念
    内存恶鬼drawRect
    UIKit 性能调优(主要是UITableView)
    优化UITableViewCell高度计算的那些事
    高性能图片架构与设计
    轻量化视图控制器
    UIView的生命周期
    高效设置圆角
    事件的传递和响应机制
    ReactiveCocoa 和 MVVM 入门

    常见知识点:
    iOS:

    你在项目中用过 runtime 吗?举个例子。
    你在项目中用过 GCD 吗?举个例子。
    Category 的实现原理,以及 Category 为什么只能加方法不能加属性。
    block 的原理,block 的属性修饰词为什么用 copy,使用 block 时有哪些要注意的?
    iOS 的热更新方案有哪些?介绍一下实现原理。
    class A 继承 class B,class B 继承 NSObject。画出完整的类图。
    细致地讲一下事件传递流程
    main()之前的过程有哪些?
    Category 中有 load 方法吗?load 方法是什么时候调用的?load 方法能继承吗?
    讲一下你对 iOS 内存管理的理解
    你在项目中是怎么优化内存的?
    讲讲 RunLoop,项目中有用到吗?
    列表卡顿的原因可能有哪些?你平时是怎么优化的?
    项目有没有做过组件化?或者你是否调研过?
    讲一下 OC 的消息机制
    ARC 都帮我们做了什么?
    实现 isEqual 和 hash 方法时要注意什么?
    property 的常用修饰词有哪些?weak 和 assign 的区别?weak 的实现原理是什么?
    线程安全的处理手段有哪些?把你想到的都说一下。
    说一下 OperationQueue 和 GCD 的区别,以及各自的优势
    Swift 中 struct 和 class 的区别
    Swift 是如何实现多态的?
    Swift 和 OC,各自的优缺点有哪些?
    如果让你实现 NSNotificationCenter,讲一下思路
    如果让你实现 GCD 的线程池,讲一下思路
    讲讲 MVC、MVVM、MVP,以及你在项目里具体是怎么写的?
    iOS 系统框架里使用了哪些设计模式?至少说6个。
    你自己用过哪些设计模式?
    哪一个项目技术点最能体现自己的技术实力?具体讲一下。
    你在项目中遇到的最大的问题是什么?你是怎么解决的?
    用 Alamofire 比直接使用 URLSession,优势是什么?
    你是如何学习 iOS 的?
    和产品经理、测试产生冲突时,你是怎么解决的?
    说说你对 OC 中 load 方法和 initialize 方法的异同。——主要说一下执行时间,各自用途,没实现子类的方法会不会调用父类的?

    说说你对 block 的理解。—— 三种 block,栈上的自动复制到堆上,block 的属性修饰符是 copy,循环引用的原理和解决方案。

    说说你对 runtime 的理解。——主要是方法调用时如何查找缓存,如何找到方法,找不到方法时怎么转发,对象的内存布局。

    说说你对 MVC 和 MVVM 的理解。—— MVC 的 C 太臃肿,可以和 V 合并,变成 MVVM 中的 V,而 VM 用来将 M 转化成 V 能用的数据。

    说说 UITableView 的调优。——一方面是通过 instruments 检查影响性能的地方,另一方面是估算高度并在 runloop 空闲时缓存。

    谈谈你对 ARC 的理解。ARC 是编译器完成的,依靠引用计数,谈谈几个属性修饰符的内存管理策略,什么情况下会内存泄露。

    MVC 具有什么样的优势,各个模块之间怎么通信,比如点击 Button 后 怎么通知 Model?

    UITableView 的相关优化
    KVO、Notification、delegate 各自的优缺点,效率还有使用场景
    如何手动通知 KVO
    Objective-C 中的 copy 方法
    runtime 中,SEL 和 IMP 的区别
    autoreleasepool 的使用场景和原理
    RunLoop 的实现原理和数据结构,什么时候会用到
    block 为什么会有循环引用
    使用 GCD 如何实现这个需求:A、B、C 三个任务并发,完成后执行任务 D。
    NSOperation 和 GCD 的区别
    CoreData 的使用,如何处理多线程问题
    如何设计图片缓存?
    有没有自己设计过网络控件?
    怎么判断某个 cell 是否显示在屏幕上
    进程和线程的区别
    UIView 生命周期
    如果页面 A 跳转到 页面 B,A 的 viewDidDisappear 方法和 B 的 viewDidAppear 方法哪个先调用?
    block 循环引用问题
    ARC 的本质
    RunLoop 的基本概念,它是怎么休眠的?
    Autoreleasepool 什么时候释放,在什么场景下使用?

    网络:

    为什么是三次握手?为什么是四次挥手?三次挥手不行吗?
    讲一下 HTTPS 密钥传输流程
    TCP 与 UDP 区别
    TCP 流量控制
    简介 TCP 和 UDP 区别,他们位于哪一层?
    路由器和交换机的工作原理大概是什么,他们分别用到什么协议,位于哪一层?
    描述TCP 协议三次握手,四次释放的过程。
    TCP 协议是如何进行流量控制,拥塞控制的?
    为什么建立连接时是三次握手,两次行不行?如果第三次握手失败了怎么处理
    关闭连接时,第四次握手失败怎么处理?
    你怎么理解分层和协议?
    HTTP 请求中的 GET 和 POST 的区别,Session 和 Cookie 的区别。
    谈谈你对 HTTP 1.1,2.0 和 HTTPS 的理解。

    算法:

    手写一下快排
    遍历一个树,要求不能用递归
    找出两个字符串的最大公共子字符串
    不用临时变量怎么实现 swap(a, b)——用加法或者异或都可以
    二维有序数组查找数字——剑指 offer 第 3题
    亿级日志中,查找登陆次数最多的十个用户——(不确定对不对,我的思路是)先用哈希表保存登陆次数和ID,然后用红黑树保存最大的十个数。剑指 offer 第 30题
    简述排序算法——快排,partion 函数的原理,堆排(不稳定),归并排序,基数排序。
    把 "www.zhidao.baidu.com" 这样的字符串改成 "com/baidu/zhidao/www"。——老题目了,剑指 offer 的,两次逆序排列即可。
    求数组中和为某个值的所有子数组,比如数组是 [5,5,10,2,3] 一共有四个子数组的和是 15,比如 [5,10],[5,10],[10,2,3],[5,5,2,3]。这个就是简单的递归了,分两种情况,当前位置的数字在子数组中,以及不在子数组中。
    数组和链表的区别
    如何找到字符串中第一个不重复的字符
    哈希表如何处理冲突
    两个无限长度链表(也就是可能有环) 判断有没有交点

    操作与编译:

    源代码是怎么变成可执行文件的,每一步的作用是什么?(预编译,词法分析,语法分析,语义分析,中间语言生成目标代码生成,汇编,链接)
    应用层、API、运行库、系统调用、操作系统内核之间的关系是什么?
    虚拟内存空间是什么,为什么要有虚拟内存空间。
    静态链接和动态链接分别表示什么,大概是怎么实现的?
    可执行文件的结构如何?(分为哪些段)
    它是怎么装载进内存的,为什么要分段,分页,页错误是什么?
    进程的内存格局是怎样的?(堆、栈、全局/静态区,代码区,常量区)
    堆和栈的区别,函数调用和栈的关系
    进程和线程的区别
    异步和同步,串行,并发,并行的区别
    多并发任务,仅多线程能加快速度么(不能,会变慢,有线程切换的开销)
    多个线程之间可以共享那些数据
    进程之间如何通信
    介绍几种锁,他们的用途和区别

    以上的内容摘自微信公众号小专栏中几位大神的精心整理,更多内容也欢迎大家去订阅

    相关文章

      网友评论

        本文标题:进军BAT复习计划一

        本文链接:https://www.haomeiwen.com/subject/zurxaftx.html