iOS_面试遇到的问题
来源:互联网 发布:尤克里里淘宝网 编辑:程序博客网 时间:2024/06/05 05:57
学习东西的方式有很多种, 面试也是一种车缺补漏的方式, 所以, 把遇到的问题总结一下, 感觉考底层实现的多一些:
1.lable 怎么从左上角开始显示内容?
答:
关于这个问题唐巧大神曾写过一篇帖子叙述的相当到位,大致有3种方式:
1.第一种也是比较简单的一种,通过修改label的高度来使文字看起来是从顶部开始显现的,即:
CGSize maximumSize = CGSizeMake(300, 9999);NSString *dateString = @"The date today is January 1st, 1999";UIFont *dateFont = [UIFont fontWithName:@"Helvetica" size:14];CGSize dateStringSize = [dateString sizeWithFont:dateFont constrainedToSize:maximumSize lineBreakMode:self.dateLabel.lineBreakMode];CGRect dateFrame = CGRectMake(10, 10, 300, dateStringSize.height);self.dateLabel.frame = dateFrame;
如果你使用的是Masobry 的话那就更容易了, 只需设置距上以及距左的距离就可以了, label会根据文字进行自适应的, 当然, 如果需要这样的话需要你设置最大宽度
2.第二种方式是在文字后边加\n 讲文字挤要最上方,即:
for(int i=0; i<newLinesToPad; i++) self.text = [self.text stringByAppendingString:@"\n "];
3.第三种是利用category的方式对UILabel进行绘制,即:
// -- file: UILabel+VerticalAlign.h#pragma mark VerticalAlign@interface UILabel (VerticalAlign)- (void)alignTop;- (void)alignBottom;@end// -- file: UILabel+VerticalAlign.m@implementation UILabel (VerticalAlign)- (void)alignTop { CGSize fontSize = [self.text sizeWithFont:self.font]; double finalHeight = fontSize.height * self.numberOfLines; double finalWidth = self.frame.size.width; //expected width of label CGSize theStringSize = [self.text sizeWithFont:self.font constrainedToSize:CGSizeMake(finalWidth, finalHeight) lineBreakMode:self.lineBreakMode]; int newLinesToPad = (finalHeight - theStringSize.height) / fontSize.height; for(int i=0; i<newLinesToPad; i++) self.text = [self.text stringByAppendingString:@"\n "];}- (void)alignBottom { CGSize fontSize = [self.text sizeWithFont:self.font]; double finalHeight = fontSize.height * self.numberOfLines; double finalWidth = self.frame.size.width; //expected width of label CGSize theStringSize = [self.text sizeWithFont:self.font constrainedToSize:CGSizeMake(finalWidth, finalHeight) lineBreakMode:self.lineBreakMode]; int newLinesToPad = (finalHeight - theStringSize.height) / fontSize.height; for(int i=0; i<newLinesToPad; i++) self.text = [NSString stringWithFormat:@" \n%@",self.text];}@end
2.view 上怎么显示文字
答:查了一下, 好像CATextlaye能够实现
CATextLayer *lary = [CATextLayer layer];lary.string = @"dasfasa";lary.bounds = CGRectMake(0, 0, 320, 20);lary.font = @"HiraKakuProN-W3"; //字体的名字 不是 UIFontlary.fontSize = 12.f; //字体的大小lary.alignmentMode = kCAAlignmentCenter;//字体的对齐方式lary.position = CGPointMake(160, 410);lary.foregroundColor = [UIColor redColor].CGColor;//字体的颜色[self.view.layer addSublayer:lary];
3.数组有什么优缺点?
优点:使用方便,查询效率高,内存为一个连续的区域
缺点:大小固定,不适合动态存储,不方便动态添加
1)数组在内存中是逐个存放的,也就是说倘若数组的第一个元素在地址A,则数组第二个元素就在地址A+1。
而链表则不是,链表每个节点没有相对固定的位置关系。某个节点在地址A其后的节点不一定是A+1,而在内存的其他空闲区域,呈现一种随机的状态。
2)数组一旦显式的被申明后,其大小就固定了,不能动态进行扩充。而链表则可以,可以动态生成节点并且添加到已有的链表后面。
3)链表灵活,但是空间和时间额外耗费较大;数组大小固定,元素位置固定,但是操作不灵活,且容易浪费空间,但是时间耗费较小,尤其是元素变化不大的时候效率很高。双向链表比单向的更灵活,但是空间耗费也更大
4.两个无序的集合, 求交(如果是数组的话有怎么搞)
答:我的一个想法就是把两个集合放在同一个数组里, 然后进行排序, 遍历数组, 判断当前项和下一项是否相同, 相同取出,(这是针对集合的,数组的没想出来)
http://blog.csdn.net/jie1991liu/article/details/13168255这里提供了更多的一些思路
5.说一下GCD
答:
GCD 其实就是并行,串行,同步, 异步的一个方法, 是基于C语言的一个封装
6.tableView 的Cell 怎么进行优化
答:查了一下, 优化的方式各不相同, 彻底干掉自身重用机制的话太浪费内存了, So 我觉得在系统方法外边在此包一层缓存机制还是比较可取的一种,
这个是一个缓存frame的方法, 感觉比我想的缓存cell更加可取http://www.cnphp6.com/archives/67108
一下是一些减少cell卡顿的方式
1)尽量使用不透明视图
2)不重复创建cell
3)减少视图数目
4)不做多余的绘制工作
5)预渲染图片
6)不阻塞主线程
7.怎样对实时更新的数据进行排序
答:此处需要用到双向链表,(具体怎么用,请听下回分解)
8.1像素的线要怎么画
9.kvc kvo的底层实现
答: KVO是基于runtime机制实现的 , 当某个类的对象第一次被观察时, 系统就会在运行期动态地创建该类的一个派生类,在这个派生类中重写基类中任何被观察属性的 setter 方法。 派生类在被重写的 setter 方法实现真正的通知机制(Person NSKVONotifying_Person)
KVC:KVC主要通过isa- swizzling,来实现其内部查找定位的
一个对象在调用setValue的时候,
(1)首先根据方法名找到运行方法的时候所需要的环境参 数。
(2)他会从自己isa指针结合环境参数,找到具体的方法实现的接口。
(3)再直接查找得来的具体的方法实现
10.AFN的内部实现
11.自动释放池在什么时候被释放(自动释放池的释放的时间点)
12.图文混编怎么用
13.__block ARC和MRC下的区别
14.__bribge 的作用
15.支付时怎么考虑安全问题
2)可多次数据加密
暂时想到的就这么多, 后期在做补充
- iOS_面试遇到的问题
- iOS_开发中遇到的那些问题_1
- iOS_开发中遇到的那些问题_6
- iOS_开发中遇到的那些问题_3
- iOS_开发中遇到的那些问题_2
- iOS_开发中遇到的那些问题_4
- iOS_开发中遇到的那些问题_5
- 面试遇到的问题
- 面试遇到的问题
- 面试遇到的问题
- 面试遇到的问题
- 面试遇到的问题
- 面试遇到的问题
- 面试遇到的问题
- 面试遇到的问题
- 面试遇到的问题
- 面试中遇到的问题
- 面试中遇到的问题
- java_JDBC连接数据库代码大全
- mac下xampp运行thinkphp错误403解决方案
- 指令汇B新闻客户端开发(二) 主页面布局
- Thrift交流(一)简单的Thrift
- Dynamic range compression
- iOS_面试遇到的问题
- 一致性hash算法 - consistent hashing
- java 集合 交集
- 算法设计与分析:第四章 动态规划 4.7 有向线段k值问题
- Linux IO及 select、poll、epoll详解
- lightoj1166Old Sorting
- 【南大软院大神养成计划:第十天】久违了,JavaScript——入门篇(二)
- java遍历目录下的包括子目录下的所有文件
- 基于分类的Vad效果