weak
首先runtime维护了一张弱引用表 也是一张hash表,key为指向对象的地址,value为weak指针的地址数组,当一个对象即将销毁的时候 首先他会调用object_release消息 又因为他的引用计数为0 所以调用dealloc 函数,接着在dealloc中调用object_rootDealloc函数 最后调用的是object_clear_dellocating函数根据对象的地址找到对应的指针数组,遍历数组将其中数据设置为nil,从而移除
消息转发
发送消息的时候首先没找到对应的方法他根据是类方法执行resoveClassMethed要是实例方法执行resoveinstanceMethod假如返回Yes消息转发结束,返回NO代表不处理继续下一步执行forwordingtargetForSelect要是返回self结束消息转发,要是返回nil,继续执行forwardingInvocation漂流瓶的方式找到响应者要是确认无响应者执行doesnotrecongernizeSelecter
用assign修饰对象会发生什么
用assign修饰对象的时候,因为没有强引用 所以创建立即释放,当你再去访问这个对象的时候 会造成野指针(对已经标记为释放地址进行读写操作的时候)野指针的行为不可预测 当该空间地址一直处于空闲会产生bad_access 当该空间被其他对象访问 但没有找到对应的实现方法的时候 提示unrecongnizer selecter to instance xxx 当该空间被访问并且对象恰好有对应的方法的时候 没有异常
为什么所有UI操作必须放在主线程?
因为uikit框架是不安全的,假设UI线程在子线程操作的话 那么会产生多条线程任务抢夺的情况,解决这种情况也可以加锁实现 但是锁会消耗性能,既然连属性都追求性能不加锁 那么苹果是不会加锁的 所以苹果规定所有的用户交互都要在主线程进行 避免多线程对UI操作
检测VC是否是内存泄漏
给VC添加分类 使用hock函数生命周期的方式延迟给VC发送消息 检测 是否有消息响应 有则代表内存泄漏
uiview与calayer关系如何
uiview是calyer的delegate
uiview响应事件calyer处理绘图
uiview比calayer多了一个锚点
NSDictionary实现原理
Hash表,hash表实际是一个数组 每一个数组内的元素称为一个bin,key为关键字通过 hash函数得到对应的位置 不需要比较 假如2个 不同的key有同样的位置 则根据拉链法 或者开放寻址法解决冲突
简述tableview如何优化
1.复用机制
2.设置cell高度的时候 要是固定行高尽量使用属性 要是不固定才使用代理 因为tableview当加载的时候 设置了几个cell 代理就执行几次
3多次使用的图片imagewithname比较合适因为苹果内部对图片进行缓存只出现1次的情况下建议多使用[uiimage imagewithcontentofile]
4.实际开发中尽量少使用离屏渲染 比如圆角 阴影 图层蒙板 使用贝塞尔曲线就能解决圆角的问题
5.尽量减少在滑动的过程中重新布局 比如复杂控件尽可能少使用约束autolayout 因为outolayout 也是重新转换成frame做运算
nsarry和nsmutableArr使用copy还是strong
Nsarry使用strong修饰的时候 只是指针引用假如后续有一个不可变的数组对象赋值给改属性 那么会造成属性的改变
Nsmuatblearray使用copy修饰 实际是产生一个全新的不可变的数组 如果使用点语法赋值会有crash
给定字符串 "hello,world",实现将其反转。输出结果:dlrow,olleh
- (void)cccd{
NSString*string =@"hello,world";
NSMutableString *tampStr = [NSMutableString stringWithString:string];
for(inti =0; i<=string.length-1; i++) {
[tampStrreplaceCharactersInRange:NSMakeRange(string.length-1-i, 1) withString:[string substringWithRange:NSMakeRange(i, 1)]];
}
NSLog(@"%@",tampStr);
}
求一个字符串第一次只出现1次的子串(时间复杂度为o(n))
- (void)hashTest
{
NSString* testString =@"hhaabccdeef";
chartestCh[11];
memcpy(testCh, [testString cStringUsingEncoding:NSUTF8StringEncoding], [testString length]);
intlist[256];
for(inti =0; i <256; i++) {
list[i] =0;
}
char*p = testCh;
charresult ='\0';
while(*p != result) {
list[*(p++)]++;
}
p = testCh;
while(*p != result) {
if(list[*p] ==1) {
result = *p;
break;
}
p++;
}
printf("result:%c",result);
}