1.用断点调试崩溃问题的小技巧
(1)如果当前断点指向内存, 那么就是初始化时分配内存时有问题
(2)添加全局断点的问题:
全局断点的目的就是当产生异常或崩溃能够停留在异常或者崩溃发生的地方而不是跳转到主函数
但是添加全局断点后会跳转到主函数, 会遇到如上图的情况, 那么80%的问题就是storyboard或者xib拖线没有及时清理掉坏线如下图:
这条Button的连线在代码中已经删除了不用了, 但是没有及时清理掉,所以会造成崩溃!
2.判断是否为gif/png图片的正确姿势
首先我们先想想如果是你, 你会怎么去判断一个从网络获取的图片URL是否为gif图片, 是否是这样呢 ? 如下:
1
2
3
4
5
6
7
8
9
|
//假设这是一个网络获取的URL
// 判断是否为gif
NSString *extensionName = path.pathExtension;
if
([extensionName.lowercaseString isEqualToString:@
"gif"
]) {
//是gif图片
}
else
{
//不是gif图片
}
|
什么难道你不是这么判断的么 ? 哦~ 我懂了, 难道你使用字符串截取来判断的吗 ? 哈哈开个玩笑!
以上判断看似是可以的,但是这不严谨的, 在不知道图片扩展名的情况下, 如何知道图片的真实类型 ? 其实就是取出图片数据的第一个字节, 就可以判断出图片的真实类型那该怎么做呢如下:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
|
//通过图片Data数据第一个字节 来获取图片扩展名
- (NSString *)contentTypeForImageData:(NSData *)data {
uint8_t c;
[data getBytes:&c length:1];
switch
(c) {
case
0xFF:
return
@
"jpeg"
;
case
0x89:
return
@
"png"
;
case
0x47:
return
@
"gif"
;
case
0x49:
case
0x4D:
return
@
"tiff"
;
case
0x52:
if
([data length] < 12) {
return
nil;
}
NSString *testString = [[NSString alloc] initWithData:[data subdataWithRange:NSMakeRange(0, 12)] encoding:NSASCIIStringEncoding];
if
([testString hasPrefix:@
"RIFF"
] && [testString hasSuffix:@
"WEBP"
]) {
return
@
"webp"
;
}
return
nil;
}
return
nil;
}
|
其实图片数据的第一个字节是固定的,一种类型的图片第一个字节就是它的标识, 我们来调用一下这个方法:
1
2
3
4
5
6
7
|
//假设这是一个网络获取的URL
NSData *data = [NSData dataWithContentsOfURL:[NSURL URLWithString:path]];
//调用获取图片扩展名
NSString *string = [self contentTypeForImageData:data];
//输出结果为 png
NSLog(@
"%@"
,string);
|
3.你是用什么方法设置图片圆角?
首先你是否是这么设置的:
1
2
3
|
//cornerRadius 设置为self.iconImage图片宽度的一半(圆形图片)
self.iconImage.layer.cornerRadius = 20;
self.iconImage.layer.masksToBounds = YES;
|
或者是在xib&storyboard中点击要设置圆角的图片:
在此之后建议大家尽量不要这么设置, 因为使用图层过量会有卡顿现象, 特别是弄圆角或者阴影会很卡, 如果设置图片圆角我们一般用绘图来做:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
|
/** 设置圆形图片(放到分类中使用) */
- (UIImage *)cutCircleImage {
UIGraphicsBeginImageContextWithOptions(self.size, NO, 0.0);
// 获取上下文
CGContextRef ctr = UIGraphicsGetCurrentContext();
// 设置圆形
CGRect rect = CGRectMake(0, 0, self.size.width, self.size.height);
CGContextAddEllipseInRect(ctr, rect);
// 裁剪
CGContextClip(ctr);
// 将图片画上去
[self drawInRect:rect];
UIImage *image = UIGraphicsGetImageFromCurrentImageContext();
UIGraphicsEndImageContext();
return
image;
}
|
这个方法就是设置圆角图片, 效率很高, 不会造成卡顿现象, 大家要把这个方法单独放到分类中使用