Debug方式

在平常写程序中,有很多地方都需要采用NSLog来定位bug,不过代码一长,寻找起来就很费时间了。将系统定义的一些表达式用在NSLog中,可以快速的帮助我们进行debug。

方法1:


- (instancetype)initWithFrame:(CGRect)frame {
    
    self = [super initWithFrame:frame];
    if (self) {
        self.backgroundColor = [UIColor clearColor];
        
        externalRadius = MIN(self.frame.size.width, self.frame.size.height) /2;
        innerRadius = 0.7 * externalRadius;
        
        self.label = [[UILabel alloc] init];
        self.label.backgroundColor = [UIColor clearColor];
        self.label.font = self.labelFont;
        self.label.textColor = [UIColor whiteColor];//self.labelColor;
        self.label.text = @"GIF";
        self.label.textAlignment = NSTextAlignmentCenter;
        self.label.numberOfLines = 1;
        self.label.frame = CGRectMake(externalRadius - sqrt(2)*innerRadius/2, MAX(self.frame.size.width, self.frame.size.height)/2 - sqrt(2)*innerRadius/2, sqrt(2)*innerRadius, sqrt(2)*innerRadius);
        [self addSubview:self.label];
        
        NSLog(@"\n Function:%s\n Pretty function:%s\n Line:%d\n File:%s\n", __func__, __PRETTY_FUNCTION__, __LINE__, __FILE__);
    }
    
    return self;
}
输出结果为:


也可以将

NSLog(@"\n Function:%s\n Pretty function:%s\n Line:%d\n File:%s\n", __func__, __PRETTY_FUNCTION__, __LINE__, __FILE__);

更换为

NSLog(@"Current Selector: %@", NSStringFromSelector(_cmd));
        NSLog(@"Object Class:%@", NSStringFromClass([self class]));
        NSLog(@"File Name: %@", [NSString stringWithUTF8String:__FILE__].lastPathComponent);

输出结果如下:


总之,需要灵活运用系统定义的预留词和Core Foundation的一些方法。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值