我正在使用NSLog检查一个UITextView.我的代码中有以下日志记录:
NSLog(@"textView: %@",textView); NSLog(@"textView.frame: %@",textView.frame); NSLog(@"[textView frame]: %@",[textView frame]);
2010-11-29 22:00:38.252 MenuMaker[57602:207] textView: <UITextView: 0x3b3afe0; frame = (0 0; 320 387); text = 'blah...'; clipsToBounds = YES; autoresize = RM+BM; layer = <CALayer: 0x3b3afa0>> 2010-11-29 22:00:38.254 MenuMaker[57602:207] textView.frame: (null) 2010-11-29 22:00:38.254 MenuMaker[57602:207] [textView frame]: (null)
第一行输出,因为它包含’frame =(0 0; 320 387)’位,导致我相信UITextView的框架变量都是设置的.但为什么在这种情况下接下来的两行显示为空?他们不应该转储框架的值吗?
提前致谢
解决方法
正如其他人所指出的,CGRect只是一个结构,因此缺少一种描述方法(这是NSString的stringWithFormat静态方法 – NSLog使用的格式字符串替换%@).因此,您不能直接将其传递给NSLog.
但是,不需要像建议一样输出任何值. Cocoa提供了许多内置的方法,将多个Core Graphics结构渲染为一个字符串:
NSStringFromCGRect() NSStringFromCGPoint() NSStringFromCGSize() NSStringFromCGAffineTransform()
等等.因此,以字符串的形式输出CGRect变得非常容易:
NSLog(@"%@",NSStringFromCGRect(rect));