gpt4 book ai didi

Xcode4 中的 Objective-C 调试技巧?

转载 作者:IT王子 更新时间:2023-10-29 08:17:22 26 4
gpt4 key购买 nike

使用 Flex-Flash IDE,我能够在我的代码中设置断点,并在运行时在相应的窗口中查看我的变量值。

现在,我想出了在 Xcode 中可以找到“变量”窗口的位置,我可以在那里看到我的所有变量,但看不到这些变量的值。我只有数据类型和一堆十六进制数(指针?)。

我应该如何调试我的代码?我在哪里可以看到我的变量值而不必将它们记录到我的代码中?

我正在尝试使用一组键/值对查看 NSDictionary 的值。但还有任何其他 NSObject 。我已经阅读了一些关于重写描述方法的内容,但是原生对象呢?

最佳答案

Debugging with GDB

XCode 为您提供了一个 GDB 调试器,所以就像 Jano 在他的评论中所说的那样,您可以使用 GDB 命令,例如 po(打印对象)来查看对象。

po myObject
po myDictionary
po myArray

要打印 int、float 等基元,您可以使用 printppx(以十六进制查看数字)

print myInt
p myInt
px myInt

您还可以看到运行命令的结果。例如,要查看字符串长度,您可以执行以下操作:

p (int) [myString length]

如果您不将返回值转换为 int,我相信您会在控制台中看到一些提示。

要查看 UIView 的框架(CGRect 结构类型),您可以:

p (CGRect) [myView frame]

最后,如果您重写一个类的 description 方法,您可以自定义它在写入控制台时的显示方式,甚至是写入 NSLog 时的显示方式。如果你执行 [NSString stringWithFormat:@"My object... %@", myObj] 将调用该对象的描述方法。

- (NSString*) description
{
return @"This is the object description!";
}

另一个不错的读物是 How to set a conditional breakpoint in Xcode based on an object string property?


日志提示

如果你想要 NSLog 消息但只在调试版本中,你可能会喜欢我们在工作中使用的 DLog 宏:

#ifdef DEBUG
#define DLog(...) NSLog(__VA_ARGS__)
#else
#define DLog(...) /* */
#endif

它的工作方式与 NSLog 类似,只是它是在非 DEBUG 版本上编译出来的。 NSLog 实际上可能会影响性能,而且您可能不希望某些消息溢出到您的日志中。

我们将这个宏放在预编译的头文件 (MyApp-Prefix.pch) 中,以便它包含在所有项目文件中。


转储变量

您的评论询问如何在不编写代码的情况下转储对象的所有变量。我知道没有内置的方法可以做到这一点。但是,您可以尝试使用反射。我有一个实现,可让您执行以下操作:

po [someObj dump]

您可以在 NSObject 上创建一个类别,以向所有 NSObject 类型添加一个方法,该方法将转储您需要的信息。我从Objective C Introspection/Reflection借了代码开始代码,但添加了代码以包含属性值。

NSObject (DebuggingAid) 类:

#import <objc/runtime.h>
@interface NSObject (DebuggingAid)

- (NSString*)dump;

@end

@implementation NSObject (DebuggingAid)

- (NSString*)dump
{
if ([self isKindOfClass:[NSNumber class]] ||
[self isKindOfClass:[NSString class]] ||
[self isKindOfClass:[NSValue class]])
{
return [NSString stringWithFormat:@"%@", self];
}

Class class = [self class];
u_int count;

Ivar* ivars = class_copyIvarList(class, &count);
NSMutableDictionary* ivarDictionary = [NSMutableDictionary dictionaryWithCapacity:count];
for (int i = 0; i < count ; i++)
{
const char* ivarName = ivar_getName(ivars[i]);
NSString *ivarStr = [NSString stringWithCString:ivarName encoding:NSUTF8StringEncoding];
id obj = [self valueForKey:ivarStr];
if (obj == nil)
{
obj = [NSNull null];
}
[ivarDictionary setObject:obj forKey:ivarStr];
}
free(ivars);

objc_property_t* properties = class_copyPropertyList(class, &count);
NSMutableDictionary* propertyDictionary = [NSMutableDictionary dictionaryWithCapacity:count];
for (int i = 0; i < count ; i++)
{
const char* propertyName = property_getName(properties[i]);
NSString *propertyStr = [NSString stringWithCString:propertyName encoding:NSUTF8StringEncoding];
id obj = [self valueForKey:propertyStr];
if (obj == nil)
{
obj = [NSNull null];
}
[propertyDictionary setObject:obj forKey:propertyStr];
}
free(properties);

NSDictionary* classDump = [NSDictionary dictionaryWithObjectsAndKeys:
ivarDictionary, @"ivars",
propertyDictionary, @"properties",
nil];
NSString *dumpStr = [NSString stringWithFormat:@"%@", classDump];

return dumpStr;
}

@end

关于Xcode4 中的 Objective-C 调试技巧?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/7650747/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com