项目代码量大了之后,寻找某个页面的功能对应的代码就比较费劲了。我来讲下平时用的比较多的一些方法。spa
好比设置viewDidLoad断点,系统会在全部的viewDidLoad方法中执行断点,包括系统自身的类UIViewController 。在定位的时候比较有帮助。(之前接手别人项目的时候用过,当时以为还挺好用的)debug
好比熟悉代码的状况,大概知道是在某个方法中执行了,那就能够设置普通的断点。在断点激活之后,能够结合lldb命令查看或者修改变量的值。code
这个是我目前用的最多的方法了orm
在Xcode中选择Debug -> view debug -> capture Hiearachy ip
而后找到控制器view对应的视图,右键print view description 会获得以下信息内存
<UIView: 0x7fae04946fb0; frame = (0 64; 414 672); autoresize = W+H; layer = <CALayer: 0x7fae04963350>>
在lldb中输入 (lldb) po [0x7fae04946fb0 nextResponder]string
就能够得到控制器的类和地址,就能够用shift + option + o 找到对应的代码位置了。it
若是当前打印的视图不是控制器对应的视图,那会输出其父视图的description,利用其内存地址再次打印nextResponder便可。io
好比当前页面有一个固定的字符常量,就能够全局搜索,大部分状况下也能找到对应的代码ast
在项目中引入自定义的宏来覆盖NSLog方法。固然若是集成了CocoaLumberjack ,用起来会更方便。
/** * 北京时间 * */ #define BeijingTimeString [[NSString stringWithFormat:@"%@",[[NSDate date]dateByAddingTimeInterval:8.0*3600]] substringToIndex:20] //调整输出的语句,显示在哪一个文件的第几行输出了内容 #ifdef DEBUG #define NSLog(FORMAT, ...) fprintf(stderr,"%s\n%s:%d\t%s\n",[BeijingTimeString UTF8String],[[[NSString stringWithUTF8String:__FILE__] lastPathComponent] UTF8String], __LINE__, [[NSString stringWithFormat:FORMAT, ##__VA_ARGS__] UTF8String]); #else #define NSLog(FORMAT,...) #endif
主要是__FILE__ 输出了代码在哪一个文件,__LINE__输出了代码在哪一行