iOS面试系列·某巨头PA金融科技公司iOS开发面试回忆

面试的时候你可能碰到面试官设的各种坑:不止喜欢问你iOS开发的一些特性和方法,更喜欢喜欢问你这些特性及方法你觉得它是怎么实现的?你觉得苹果公司为什么要这样设计?

也许面试官自己也没自己实现过,毕竟有些东西苹果为什么这样设计,若不是苹果公司的工程师无法知道。

但作为面试者,这个些问题正是拉开差距的最好办法:不一定要你亲手用C去重现苹果的机制,但可以谈谈你的见解和看法。所以,这一块最好有个准备。

1. 用法实践篇

一般,会问你怎么实现某个模块,用过哪些API,介绍下他们的用法。

1.1 你以前的项目架构是怎样的?
  • 我用的MVVM,相对于传统的MVC,主要区别就是把网络请求和业务层放到ViewModel里面了。
  • 相对于普通博客介绍的View<->ViewModel <->Model,其实更靠谱的理解是View <-> C <-> ViewModel <->Model,把Controller加进去,更好的理解。
  • 然后,为了让View和ViewModel之间能够有比较松散的绑定关系,于是我们使用ReactiveCocoa,KVO,Notification,block,delegate和target-action都可以用来做数据通信,从而来实现绑定,但都不如ReactiveCocoa提供的RACSignal来的优雅,如果不用ReactiveCocoa,绑定关系可能就做不到那么松散那么好,但并不影响它还是MVVM。
  • 这里推荐一个MVVM基础框架:https://github.com/foxsofter/LPDMvvmKit
1.2 你是如何数据建模的?
  • 普通的办法就是建一个基类比如BaseModel,里面写好一些初始化的方法,然后新建一个子类比如UserModel,里面写好一些跟后台对应的字段,用它来接收数据或者保存数据。这一块可参考:https://www.jianshu.com/p/923404fcd2f2
  • 还有一种办法,就是封装一个功能,根据网络请求返回来的JSON数据自动生成Model文件,当然也提供特许字段的处理,比如id字段。它的缺点就是如果接口的JSON的数据是动态可变的,还是需要手动调整补充。这个可参考:https://blog.csdn.net/lg767201403/article/details/78675788
  • 当然,还有一种办法,就是有个软件叫JSONExport,可以实现上面封装的那个功能,不过这种方法生成的更慢。
1.3 你怎么实现字典转模型的?
  • 我原来的老工程里面用的是MJExtesion,它的兼容性更高。当然JSON层数不多的时候,我也会自己实现字典转模型,主要利用两个API:
- (void)setValuesForKeysWithDictionary:(NSDictionary<NSString *,id> *)keyedValues;

- (void)setValue:(id)value forUndefinedKey:(NSString *)key{}
1.4 你用过哪些动画效果?
  • 最基本的就是UIView动画了,不涉及任何CAAnimationtion提供的API,这个就包括了两类frame动画(涉及一些frame, bounds, center的改变),transform动画。关于它的取值可以这样:
imageContainView.frame = CGRectMake(80, 80, 200, 200); 
  • frame动画基本利用的属性就是UIView的.frame.bounds.center属性。
  • transform动画利用的就是UIView的.transform属性。至于它的取值可以类似如下这样,只要CGAffineTransform类型即可。
self.redView.transform = CGAffineTransformTranslate(self.redView.transform, 0, 0);
self.redView.transform = CGAffineTransformMakeRotation(M_PI);
self.redView.transform = CGAffineTransformMakeScale(1.5, 1.5);
  • 当涉及一些frame, bounds, center的改变或是形变的时候其实可以用 transform方式 来取代 frame方式。
  • UIView动画基本的语法形式就是两种,一个是UIView的begin --- commit,一个是UIView的animations block了。
  • 再就是直接利用核心动画CAAnimation及其子类的API了,包括基础动画,组动画,转场动画,关键帧动画,形变动画。这种动画的基本形式就是新建一个CAAnimation子类例如CAKeyframeAnimation,然后向animatedView.layer视图添加动画效果
/**
 *  抖动效果
 */
-(void)shakeAnimation{
    CAKeyframeAnimation *anima = [CAKeyframeAnimation animationWithKeyPath:@"transform.rotation"];//在这里@"transform.rotation"==@"transform.rotation.z"
    NSValue *value1 = [NSNumber numberWithFloat:-M_PI/180*4];
    NSValue *value2 = [NSNumber numberWithFloat:M_PI/180*4];
    NSValue *value3 = [NSNumber numberWithFloat:-M_PI/180*4];
    anima.values = @[value1,value2,value3];
    anima.repeatCount = MAXFLOAT;
    
    [_demoView.layer addAnimation:anima forKey:@"shakeAnimation"];
}
  • CG动画,比如我实现过一个类似芝麻分半圆形动画的效果。这个动画中,色彩渐变是通过CAGradientLayer实现的,设置好参数后,设置它的蒙层即可,例如gradientLayer.mask = self.graView.layer;。关于,CG绘制的具体代码,可参考如下:
还有 38% 的精彩内容
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
禁止转载,如需转载请通过简信或评论联系作者。
支付 ¥9.90 继续阅读
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 206,126评论 6 481
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 88,254评论 2 382
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 152,445评论 0 341
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 55,185评论 1 278
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 64,178评论 5 371
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,970评论 1 284
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 38,276评论 3 399
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,927评论 0 259
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 43,400评论 1 300
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,883评论 2 323
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,997评论 1 333
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,646评论 4 322
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 39,213评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,204评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,423评论 1 260
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 45,423评论 2 352
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,722评论 2 345

推荐阅读更多精彩内容