面试
我面试了大大小小的各种公司,BAT、bigo、字节、快手、伴鱼等,因为一些起因,也拒面了一些公司,拿了几家的offer。
伴鱼
伴鱼是我筹备后加入的第一轮面试,有很多本人筹备得不是很全,也没有齐全进入面试状态,面试后果不是很好,一面就挂了。
看到本文章如果你正在跳槽或者正筹备跳槽无妨动动小手,增加一下咱们的交换群563513413来获取一份具体的大厂面试材料为你的跳槽多添一份保障。
一面
- 算法题:判断均衡二叉树(easy)
- 代码浏览题:(问输入)
TestObject *object1 = [[TestObject alloc] init];
__block TestObject *object2 = [[TestObject alloc] init];
object1.name = @"Mike";
object2.name = @"Sean";
__block int vi = 1;
void (^handler)(NSString ) = ^(NSString name) {
object1.name = name;
object2.name = name;
vi = 2;
}
handler(@"Lucy");
NSLog(object1.name);
NSLog(object2.name);
NSLog(@"%i", vi);
引申:
- 如果__block int vi = 1; 这句改成int vi = 1会怎么,为什么
- 代码中的block是什么block,为什么
- weak的实现原理
- weak弱援用表是可变的么还是不可变的
- weak是在什么时候置nil的,如果同时有很多对象对性能影响大怎么办
- UIView 和 CALayer的关系和区别
- UIView 和 CALayer在动画上的区别
- frame和bounds在什么状况下是不相等的
- bounds x,y 肯定是0,0么,为什么
- bounds 改成 (50, 50, width, height)会产生什么,view自身,子View?
58
58我面了很屡次,一开始面的根底研发部门,起初给我转到了企业工具研发,两头工夫拖得有点长,间接拒面了。
一面
- 说下你在开发过程中遇到过的内存透露
- NSTimer 怎么解决内存透露
- Delegate什么状况下会呈现内存透露,怎么解决
- Delegate和Notification的区别
- 多线程相干
- iOS中有哪些多线程技术
- 如果有两个同步工作嵌套会怎么
- 常见的锁,为什么要加锁
- C依赖AB工作执行完能力执行,你怎么设计
- 读写锁底层怎么实现
- JavaScriptCore相干
- 什么是JavaScriptCore,JS和Native是怎么进行通信的
- 你晓得hybrid么,说说你平时怎么应用的(因为没怎么接触过间接说的不会)
- 前面就是聊天了,两头交叉问了下动静库和动态库的却别
二面(终面)
58这个部门的面试就两轮,二面是群面(几个人轮流面你),第一次接触这种面试模式,压力还是有点的。
- 对我的项目表感兴趣,后面聊了不少我的项目的内容,问了下我的项目的背景,做了啥以及有哪些收益
- 理解业内性能优化是怎么做的么
- 你我的项目中是怎么做性能优化的
- ReactNative相干
- RN的原理
- RN和flutter的区别
- 你晓得RN拆包么,RN为什么要拆包
- JS是单线程的是怎么和native多线程进行交互的(这个问题有点奇葩)
- JS和native通信的数据结构是什么
- 你们公司对于线上JSError做了哪些事件是怎么解决的
- 你有什么想问的么
一个守业公司
这个守业公司全程都是在聊天,前面问了些和iOS没多大关系的问题,而后就发了口头offer。
- 聊天:在公司中学到了啥,为啥要来北京等
- 有一个10个G的文件外面每一行都有数字,对这些数字进行排序(两种办法)
- 怎么将黑白的图片专程黑白的
- Web渲染和Native渲染有什么异同点
拼多多
拼多多应该是本人面的一个绝对较大的公司,面试过程中和面试官有了点小一致,前面问我源码在哪个文件哪一行,前面问得问题也基本上是我之前没怎么接触过的。
一面
- 算法: 手写LFU(用字典写了二十多分钟,面试官让优化只晓得能够用双链表优化,然而个体没能写进去)
- 一个操作如果耗时5s后返回nil,否则返回一个字符串,你怎么设计(要求手写代码)
- GCD中常见的操作(要求写代码)
- Struct中有一些成员变量占多少字节
- 一个OC对象在iOS中所占内存的字节数(这边和面试官争了下,我说是iOS中至多16个字节,因为内存对齐,面试官问你确定我说我确定,而后就有了前面的问题)
- 你看过alloc的源码么,你刚刚说的代码是在哪个文件哪一行
- dealloc的整个过程
- NSURLSession相干的内容(具体忘了)
- web和native怎么共享cookie
- xx(前司)有动静库打包么,你看过xx ipa(前司app)的构造么
- 内联函数和一般函数的区别
- 怎么hook一个C函数
- 有什么想问的么
百度
百度问得和iOS相干的较少,CS根底绝对较多。
一面
- 聊我的项目:次要问了我的项目的技术栈抉择,以及我的项目中有哪些难点
- http header 和 body
- GET和POST申请
- GET申请参数肯定是放在URL中的么
- HTTPS (TLS是啥,怎么建设连贯等)
- 动静库和动态库的区别
- +load 和 initialized办法的区别
- +load的调用机会
- +load分类中的解决
- 分类的实现机制
- 分类和类别的区别
- 分类中增加属性
- 关联对象的原理
- 算法:有一个很大的整形数据,转成二进制求1的个数(因为后面聊比拟多,只要求说了下思路)
二面
- 聊我的项目:本人我的项目偏后端,问了很多和后端相干的内容,后续问的问题也基本上要求从客户端和后端双重角度答复
- 你理解的网络协议
- HTTP和TCP、UDP的分割
- HTTP和HTTPS的区别
- HTTPS的原理
- 在HTTPS建设连贯的时候都用了哪些加密算法,为什么要这么设计
- 常见的加密算法
- 对称加密算法和非对称加密算法的区别
- 说说点击一个按钮后关上一个web页面从发送网络申请到页面展现都做了啥
- 为什么能通过一个URL就能申请到对应的资源(域名解析等)
- 如果客户端上有个按钮,点击会触发一次网络申请,在短时间内疾速点击,怎么解决(从客户端以及服务端角度思考)
- 晓得什么是HTTPDNS么
- GET申请和POST的区别,POST申请参数能放在URL中么为啥
- 你理解的HTTP申请响应状态码
- 说说为什么要设计304这个状态码
- Web登录时怎么放弃会话状态的
- 你晓得cookie和session的区别么
- 你晓得常见的网络攻击么
- 什么是中间人攻打原理,怎么预防
- 平时用过抓包工具么,说说抓包的原理
- 如果让你设计一个HTTPS抓包你回怎么设计
- 过程和线程的区别是啥
- 过程的通信机制
- 过程A和过程B通过管道通信的话是在同一个管道么
- 多线程容易呈现的问题,怎么解决
- 死锁产生的条件以及对应的解决方案
- 自旋锁和互斥锁的却别
- 什么是虚拟内存,虚拟内存和物理内存的关系和区别
- 行间的换页算法有哪些
- LRU、LFU
- 持续问我的项目,为啥要做这些货色,碰到了什么难点
- 你感觉你的劣势和毛病是啥
- 本人的将来布局
- 还有什么想问的么
三面
- 百度三面中次要问的和职业规划相干的内容,没有太多的参考价值,这边不再叙述
腾讯
因为一开始是在音乐的流程里,约面工夫绝对较晚,pcg那边想和我先聊下,而后再做抉择,于是腾讯面了腾讯音乐和PCG两个部门
PCG
pcg在音乐之后面,面完一面后说一面过了,然而因为流程在音乐,所以让我抉择一个流程走,我选了音乐,起初音乐挂了后没有好意思去舔回来。
一面
- 聊我的项目
- category的实现原理
- weak的实现原理
- 开发中遇到的crash
- 怎么解决这些crash的,有什么好的解决方案么
- 循环援用问题,怎么解决
- NSTimer相干,和runLoop的关系
- NSTimer、CADisplayLink以及GCD Timer的比照
- 算法:求N!
腾讯音乐
腾讯音乐感觉业务不是很多口,感觉面试官不晓得问我什么好,一面后就没有后续了。
一面
- 后面聊我的项目:背景收益等
- 想看机会的起因
- RN是这么做到和native通信的
- 如果让你实现RN的成果你会怎么设计(这个问题看你功底了)
- Native是怎么将办法裸露进来的
- 需要中的难点,你是怎么解决的
- A调用了B办法都做了什么事件
- ISA指针
- 64位后怎么获取ISA指针
- runloop、runtime工作中有接触过嘛
- 手指触摸屏幕后零碎都做了哪些事件
- 怎么监听页面的卡顿
- 怎么监听函数执行工夫
- 还有什么想问的么
微博
微博有点迷,感觉面试官就是对着题库问问题,感觉本人答复还OK,然而一面后不了了之了。
一面
- 基本上都是一些iOS的根底,和本文面经提到的高度反复,不再叙述。
Bigo
Bigo整个流程推动很快,一面二面都在当天实现,然而bigo三面后挂了,有点迷,我猜想是因为二面的算法题没有给出最优解。
一面
- 算法(三道手写)
- 字符串转整形
- 反转链表(递归和非递归)
- 将两个有序链表合并成一个有序链表
- iOS根底:
- Objective-C的内存治理
- ARC和MRC的区别
- Timer的应用,怎么防止循环援用
- autoreleasePool的底层实现机制
- autoreleasePool的底层数据结构,为什么要这么设计
- iOS中常见的多线程技术
- 常见的锁,有什么区别
- 如果让你设计读写锁,你怎么设计
- RN、flutter、weex:
- 你怎么对待这些动态化技术
- RN、flutter以及weex的区别
- RN怎么和native通信的
- 前面简略聊了下将来的布局
二面
- 算法: 山脉数组找目标值(要求logN的工夫复杂度)
- QA发现了一个按钮无奈响应点击事件,可能是什么起因导致的(说了五种状况如同没有答到面试官要的点)
- iOS响应者链,怎么寻找最合适的响应者,如果为nil会怎么办
- frame和bounds的区别
- 如果bounds的origin不是00会怎么
- 你平时用过Charles么,说说Charles的抓包原理
- Charles能抓HTTPS么,怎么实现
- HTTPS怎么建设连贯的
- 中间人攻打,怎么防止
- 多线程个别会有什么问题,请举个例子
- 为什么会造成上述问题以及解决方案
- 主队列和主线程的关系
- 全局并发队列肯定在主线程上运行的么
- 我的项目相干,用了什么技术,有哪些难点,怎么解决的
三面
- 自我介绍
- 为啥想看机会
- 聊了下我的项目
- 怎么对待RN、Flutter
- 平时有看过什么技术书籍吗
- 有看过开源框架吗
- 工作中遇到最难的事件前面是怎么解决的
- 有什么想问的么
看完文章如果你正在跳槽或者正筹备跳槽无妨动动小手,增加一下咱们的交换群1012951431来获取一份具体的大厂面试材料为你的跳槽多添一份保障。
贝壳找房
贝壳找房也感觉有点迷,和面试官感觉聊很不错,问得问题都很凋谢,很考验功底,最初还问我你感觉你过了么。然而一面后就没有而后了。
一面
- 自我介绍
- 聊我的项目
- GCD 看你能说些啥
- Runtime看你能说些啥
- 内存治理看你能说些啥
- 几个简略的链表问题(具体忘了)
- 有什么想问的,以及依据简历给我的一些倡议(简历偏差全栈,意思是我工作工夫还不是很长,须要有深度,广度相干的能够后续再思考)
完满世界
完满的面试有点匆忙,面试的问题也很有深度,后续因为必须要去现场面试,出于平安因素思考,没有去面上来。
一面
- 自我介绍
- 我的项目中遇到的问题,怎么解决的
- 聊了聊OC中的内存治理
- 一个对象什么时候会援用计数+1,什么时候援用计数-1
- 对象A copy后生成字符串对象B AB援用计数是怎么的
- 如果A是可变的呢
- 关键字,readonly有理解吗
- 润饰对象的默认关键字是啥
- category相干,category是怎么实现的
- category的构造
- category中的办法会笼罩原来类的办法吗
- category中怎么辨别开类办法和实例办法的
- category的办法是怎么插入到类(元类)对象办法列表中的
- 同时最多执行5个工作怎么设计
- AFN中 success 和 fail block是在子线程还是主线程
- 不通过回到主队列的形式回到主线程(有点没get到点)
- SDWebImage的下载原理
- 如果有两个雷同的url,SDWebImage是怎么解决的
- 算法:有个view有很多子view,没个子view中也有很多子view,找出所有的按钮,并切圆角(图的BFS)
滴滴
滴滴效率是真的高,面试流程一早晨走完,当晚出后果,从面试到发offer仅仅用了4天左右的工夫。
一面to终面
- 次要波及iOS(runtime、runloop、内存治理等)
- 计算机网络(HTTP、HTTPS、TCP/UDP等)
- 操作系统(过程线程、过程通信、中断的一些机制以及一些换页算法等)
- 算法根底(常见的一些链表、树以及数组算法题)
ps:面试题之前均有波及,不再详写
猿辅导
猿辅导面试还是有点难度的,算法写完还要跑case,第二道题目跑case不正确,看代码debug,前面因为工夫不够没有给出正确后果,前面就没有后续了。
一面
- 聊我的项目(次要是我的项目中的一些技术点)
- 聊对大前端的认识(weex、RN、Flutter比照等)
- JS是怎么实现继承的,什么是JS的原型链
- iOS内存治理(援用计数、修饰词、weak和assign的区别)
- runtime(什么是runtime,为啥要有runtime,你用runtime做过什么事件)
- 怎么进行办法的替换
- +load在什么时候调用的,对启动的影响
- 代码题:ABCDE五个工作,D依赖AB的执行,E依赖BC的执行,怎么设计
- GCD信号量,线程同步等
- Runloop是啥,为啥要设计runloop,runloop和线程的关系
- Timmer为啥会有内存透露的景象,Runloop会持有Timmer么
- 什么是source0和source1,别离做什么事件
- 怎么监测app卡顿
- UIView 和 CALayer的区别,为什么要这么设计
- 隐式动画和显示动画的区别
- 算法:两题LC medium(都要求写完跑case)
- 给定一个数字n 求出全副汇合(n = 3 输入 [[],[1],[2],[3],[1,2],[1,3],[2,3],[1,2,3]])
- Lc 200 求岛屿个数
高德
这边有个小插曲,因为之前高强度的面试,前面拿了几个不错的offer后就不太想持续面了,感觉面试状态也是一个正态分布的曲线,拒了高德面试后hr找我聊了下,而后又许可持续面试,前面因为本人的确没有施展出失常的程度,导致一面挂了,不过hr起初请我喝了杯咖啡还是蛮开心的。
一面
- 聊我的项目
- JS是怎么和Native通信的
- 模块表是怎么生成的
- JS函数注入怎么做的
- RN 和 Weex 的区别
- HTTP 申请头
- HTTP 状态码
- 分类和extension区别
- 分类的实现机制
- 分类同名办法的调用
- 关联对象,策略有哪些,关联对象的key为啥要用static润饰(这个没有get到点)
- GCD、NSThread以及NSOperation的区别,怎么勾销工作
- GCD block内存治理
- 本人实现一个函数,其中有个形参是block,这个block是什么时候进行copy的,肯定会进行copy操作嘛
- 手指点在高德地图上的一个按钮,会产生什么 ,具体阐明
- 怎么找到最合适的view
- 如过有多个子VC,是先VC还是先View
- Runloop是怎么监听到点击事件的
- Runloop和线程的关系,Runloop能独自存在嘛
- 怎么做到线程保活
- A蕴含B蕴含C,怎么做能力让C的点击响应区域是 以C对角线为半径的圆弧(要说出具体实现形式)
- 代码题:
- 下方代码中三个数组中的p.name是啥,为什么
Person *p = [[Person alloc] init];
p.name = @"zhangsan";
NSArray *a = @[p];
NSArray *b = [a copy];
NSArray *c = [a mutableCopy];
Person *p2 = [c firstObject];
p2.name = @"lisi";
- 下方代码会有什么问题,为什么
NSNotificationCenter *__weak center = [NSNotificationCenter defaultCenter];
id __block token = [center addObserver:kDdiRegisterNotification
object:nil
queue:[NSOperationQueue mainQueue]
usingBlock:^(NSNotification *note) {
[self getDataWithComplete:completeBlock];
[center removeObserver:token];
}];
字节跳动
字节面了两个部门,一个是头条还有一个是抖音,字节是在我回去动了个小手术前面的,面试也不是很在状态。
头条
一面(穿插面)
- 首先是一组代码,问有啥代码格调不妥的中央(代码遗记了)
- MRC 和 ARC 的区别
- ARC有什么毛病
- MRC 下 写setter办法
- 代码题:(1、输入什么 2、如果是在自线程中会怎么样)
NSLog(@"1");
dispatch_sync(^{
NSLog(@"2");
});
NSLog(@"3");
- 你了解的id 以及 id 和 void *区别
- 函数指针和指针函数的区别
- CALayer 和 UIView的关系
- 苹果为什么要这么设计
- frame、bounds、center
- layoutIfNeeded、layoutSubViews、setNeedsDisplay区别
- 响应者链(顺便说了下残缺的手指触摸屏幕会产生什么引出了后续runloop相干问题)
- runloop source0 和 source1都是啥
- runloop和线程的关系
- OC 音讯发送机制(提到了isa、类对象,引出上面问题)
- 写下类的构造
- isa在32为和64位的区别
- 什么是元类为啥要这么设计
- category 和 extension 的区别
- +load办法
- 算法题 判断镜像二叉树
二面
- 自我介绍
- 聊我的项目
- Weex和RN以及flutter的区别
- 要是收到了内存正告怎么办
- 循环援用和内存泄露
- Block造成循环援用的原理
- Runloop和Timer的关系
- Runloop能有很多Timer么
- 什么是source0 和 source1
- Timer肯定是准时的吗,为什么
- FPS怎么监控,上传机会
- 算法:两数之和(要求空间复杂度O(1))
抖音
抖音面试有点迷,感觉面试官和我齐全在两个频道,面试官问的内容我明明答复了然而他恕我啥都不会,不晓得是不是没有get到他的点。
一面
- 聊我的项目
- iOS中+load 和 initialized区别
- iOS润饰属性罕用的修饰符
- weak和strong的区别
- strong和unsafe_unretained区别
- 什么是单例
- 对象的比拟
- 算法:开根号(要求跑case)
快手
快手也是在我动完小手术前面的,我感觉面试施展失常,和面试官聊也不错,然而玄学的是本人还是挂了,前面有其余BG想捞也不想面了。
一面
- 自我介绍
- 在学校都做了哪些项目
- 聊公司我的项目
- 常见的crash
- 怎么解决这些crash
- 怎么设计一个crash日志回捞零碎
- Objc为啥要设计音讯发送机制,间接调函数不好吗
- 怎么获取函数的堆栈
- 怎么监控APP卡顿
- APP启动做了哪些事件怎么优化
- +load
- 怎么进行业务解耦
- APP性能优化相干
- 设计一个下载工作
- 能够并行也能够串行
- 有最大的并发数量
- 能够断点续传
- 如何解耦
- 缓存怎么设计(说了LRU、LFU)
- 微信底部四个tab 蕴含首页让你实现要多久,为什么(这个真的没有明确是想问啥)
- 算法:链表反转
总结
一天四轮的面试的确是高强度的,一天下来整个人会很疲乏,导致后面拿到了一些offer后,紧绷的弦马上就松懈下来了,前面几轮高德、字节以及快手的面试都没有施展出本人应有的程度,所幸的是整体后果差强人意。面试须要一直复盘总结,不至于这次面试问的问题不懂下次还不懂,还有常识须要一直积攒,不能再长期抱佛脚了。
简历
简历决定着你是否有面试机会,一份好的简历能够让你事倍功半。
- 能够去网上找一份简历模板
- 简历尽量精简,最好能管制在一页A4纸
- 要做一些取舍,校园经验尽量不要写了
- 形容我的项目倡议用STAR法令(说分明我的项目背景、指标、做了哪些事件获得了哪些成绩)
- 本人不是很熟的货色就不要写了,感觉只有写到简历上面试官就默认你精通
iOS相干
iOS有很多货色咱们是看不到具体的实现的,毕竟是闭源的,然而咱们能联合咱们的一些教训去猜想苹果的一些实现形式。目前iOS面试问的问题越来越细,越来越底层,所以浏览一些源码是及其有必要的,iOS个别常考的点如下(这边列举得可能并不是很全):
- Objective-C语言相干
- OC的内存治理(ARC、MRC、autoReleasePool等)
- OC类的构造,class_ro_t、class_rw_t等
- OC的音讯机制
- KVC、KVO
- OC的运行时,能做哪些事件
- OC的一些个性(weak的实现机制等)
- 分类和类别
- isa指针
- super与superClass
- dealloc
- KVC以及KVO
- block(类型、变量捕捉等)
- 循环援用问题
- swift相干:
- 笔者没怎么接触过swift这边就不写了
- iOS相干
- UIView和CALayer的区别
- CoreAnimation
- 多线程(GCD、NSOperationQueue)
- runLoop以及runLoop的实现原理
- 响应者链
- Timer(NSTimer、CADisplayLink以及GCD Timer)
- iOS渲染的常识
动态化技术(加分项)
- 怎么对待这些技术
- 须要理解下ReactNative、Flutter以及Weex等支流动态化技术的优缺点
- 依据理论状况理解下ReactNative或Flutter等动态化技术的实现原理
- 理解下JavaScriptCore,晓得和native的通信机制
CS根底
这部分次要看你根底是不是扎实了,作为一名RD,不论做什么,这些常识都是要把握的。
操作系统
- 过程和线程
- 过程通信
- 虚拟内存和物理内存
- 常见的调度、换页算法
- 中断机制等
计算机网络
- OSI七层模型
- 常见的协定(HTTP、HTTPS、TCP、UDP)
- HTTP报文格式
- GET、POST却别
- HTTP状态码
- HTTP和HTTPS的区别
- HTTPS的连贯建设机制
- TCP三次握手以及四次挥手,为什么要三次握手,四次挥手少一次会怎么
- TCP和UDP区别
- TCP的一些平安机制(用塞管制,较验和等)
- 域名解析等
编译原理
- 编译的过程
- 怎么进行一些优化等
算法(脱离编译器手写,最好能肉眼debug)
算法基本上是工程师面试必然考查的点,当初越来越多的公司面试考查算法,作为iOS开发的同学,在面试之前至多要刷下《剑指offer》上的所有题目,这本书上的题目都是经典中的经典,面试呈现概率极高。有工夫的话能够刷下LeetCode上easy和medium难度的题,iOS面试,很少有考查hard的题目,然而就算是遇到hard的题目也不要过于缓和,认真审题,寻找突破口。算法是一个积攒的过程,当初LeetCode能够每日打卡,这是一个很好的积攒伎俩。上面列举下常考的数据结构和算法:
- 数据结构
- 数组
- 链表
- 树
- 算法
- 二分(就自己教训来看呈现概率极高)
- 分治
- 排序(8大排序)
- 树的遍历(前、中,后)
- BFS以及DFS
- DP(呈现概率较低)