iOS 开发中你是否遇到这些经验问题

1.用断点调试崩溃问题的小技巧

(1)如果当前断点指向内存, 那么就是初始化时分配内存时有问题

(2)添加全局断点的问题:

2353624-6e6f508188bfe97a.png

全局断点的目的就是当产生异常或崩溃能够停留在异常或者崩溃发生的地方而不是跳转到主函数

1471576838158911.png

但是添加全局断点后会跳转到主函数, 会遇到如上图的情况, 那么80%的问题就是storyboard或者xib拖线没有及时清理掉坏线如下图:

2353624-5c4a15bb16ed6d32.png

这条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中点击要设置圆角的图片:

2353624-cce526062c2d783a.png

在此之后建议大家尽量不要这么设置, 因为使用图层过量会有卡顿现象, 特别是弄圆角或者阴影会很卡, 如果设置图片圆角我们一般用绘图来做:

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;
}

这个方法就是设置圆角图片, 效率很高, 不会造成卡顿现象, 大家要把这个方法单独放到分类中使用


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值