我希望能够调试C结构,而不必显式地键入它们所包含的每个属性。

例如,我希望能够做这样的事情:

CGPoint cgPoint = CGPointMake(0,0);
NSLog(@"%@",cgPoint);

显然'%@'不起作用,因此出现了这个问题。


当前回答

NSLog(@"%@", CGRectCreateDictionaryRepresentation(rect));

其他回答

你可以试试这个:

NSLog(@"%@", NSStringFromCGPoint(cgPoint));

UIKit提供了许多函数,可以将各种CG结构转换为nsstring。它不起作用的原因是%@表示一个对象。CGPoint是一个C结构体(CGRects和CGSizes也是)。

我使用下面的宏来帮助我用NSRect:

#define LogRect(RECT) NSLog(@"%s: (%0.0f, %0.0f) %0.0f x %0.0f",
    #RECT, RECT.origin.x, RECT.origin.y, RECT.size.width, RECT.size.height)

你可以为CGPoint做类似的事情:

@define LogCGPoint(POINT) NSLog(@"%s: (%0.0f, %0.0f)",
    #POINT POINT.x, POINT.y);

使用方法如下:

LogCGPoint(cgPoint);

将产生以下内容:

cgPoint: (100, 200)

有几个函数,比如:

NSStringFromCGPoint  
NSStringFromCGSize  
NSStringFromCGRect  
NSStringFromCGAffineTransform  
NSStringFromUIEdgeInsets

一个例子:

NSLog(@"rect1: %@", NSStringFromCGRect(rect1));

由于Stack Overflow的坏RSS刚刚为我复活了这个问题,这里是我的几乎通用的解决方案:JAValueToString

这允许您编写JA_DUMP(cgPoint)并记录cgPoint ={0,0}的日志。

NSLog(@"%@", CGRectCreateDictionaryRepresentation(rect));