ios – 使用NSLog的奇怪行为

我正在使用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));

您可以在“字符串转换”下找到所有这些帮助方法here.

相关文章

UITabBarController 是 iOS 中用于管理和显示选项卡界面的一...
UITableView的重用机制避免了频繁创建和销毁单元格的开销,使...
Objective-C中,类的实例变量(instance variables)和属性(...
从内存管理的角度来看,block可以作为方法的传入参数是因为b...
WKWebView 是 iOS 开发中用于显示网页内容的组件,它是在 iO...
OC中常用的多线程编程技术: 1. NSThread NSThread是Objecti...