objective-c - 为什么 DTrace 有时但不总是给我无效地址错误?

标签 objective-c cocoa macos dtrace

我的程序:

typedef struct objc_class {
    struct objc_class *isa;
    struct objc_class *super_class;
    char *name;
    long version;
    long info;
    long instance_size;
    void *ivars;
    void *methodLists;
    void *cache;
    void *protocols;
} *Class;
struct objc_object {
    Class isa;
};

/* Code to extract the class name from arg0 based on a snippet by Bill Bumgarner: http://friday.com/bbum/2008/01/26/objective-c-printing-class-name-from-dtrace/ */

objc$target:NSObject:-init:entry {
    printf("time: %llu\n", timestamp);
    printf("arg0: %p\n", arg0);
    obj = (struct objc_object *)copyin(arg0, sizeof(struct objc_object));
    printf("obj: %p\n", obj);
    printf("obj->isa: %p\n", obj->isa);
    isa = (Class)copyin((user_addr_t)obj->isa, sizeof(struct objc_class));
    printf("isa: %p\n", obj->isa);
    classname = copyinstr((user_addr_t)(isa->name));
    printf("classname: %s\n", classname);
}

一些输出:

dtrace: script 'test.d' matched 1 probe
dtrace: error on enabled probe ID 1 (ID 61630: objc5936:NSObject:-init:entry): invalid address (0x90206b98) in action #8 at DIF offset 28
dtrace: error on enabled probe ID 1 (ID 61630: objc5936:NSObject:-init:entry): invalid address (0x90206b98) in action #8 at DIF offset 28
dtrace: error on enabled probe ID 1 (ID 61630: objc5936:NSObject:-init:entry): invalid address (0x90206b98) in action #8 at DIF offset 28
CPU     ID                    FUNCTION:NAME
  0  61630                      -init:entry time: 28391086668386
arg0: 1291ae10
obj: 6f0a1158
obj->isa: a023f360
isa: a023f360
classname: NSBitmapImageRep

  1  61630                      -init:entry time: 28391586872297
arg0: 12943560
obj: 6f4a1158
obj->isa: 2fca0
isa: 2fca0
classname: GrowlApplicationTicket

  1  61630                      -init:entry time: 28391586897807
arg0: 152060
obj: 6f4a1280
obj->isa: 2fe20
isa: 2fe20
classname: GrowlNotificationTicket

  2  61630                      -init:entry time: 28391079142905
arg0: 129482d0
obj: 700a1128
obj->isa: a0014140
isa: a0014140
classname: NSDistributedObjectsStatistics

  2  61630                      -init:entry time: 28391079252640
arg0: 147840
obj: 700a1250
obj->isa: a0014780
isa: a0014780
classname: NSDistantObjectTableEntry

为什么会出错?它似乎是类名(这是唯一的%s,如果我删除它,我不会得到任何错误),但为什么它认为某些类的名称是无效指针?

有什么方法可以让错误消息真正告诉我 DTrace 程序的哪一行导致了问题?

有没有办法调用 object_getClassName 而不是执行这种结构检查舞蹈?

就其值(value)而言,我正在跟踪的程序运行良好——它没有崩溃,所以我不相信这些类真的被破坏了。

最佳答案

Colin 非常接近正确。

参见:

http://www.friday.com/bbum/2008/01/03/objective-c-using-dtrace-to-trace-messages-to-nil/

很有可能,您需要将 DYLD_SHARED_REGION 环境变量设置为 avoid。 dtrace 仅适用于实际驻留在物理内存中的映射内存。

您可以使用 vmmap 命令行工具找出缺少的内容。

在生成上述失败消息后,对您的应用程序执行 vmmap PID。查看输出,看看像 0x90206b98 这样的地址属于哪个区域。给定该地址,它很可能在一个不可写的共享内存块中,该内存块可能不是驻留的,因此 dtrace 无法从中读取。

关于objective-c - 为什么 DTrace 有时但不总是给我无效地址错误?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/1198114/

相关文章:

iphone - 在iPhone上读取5000行文本文件

objective-c - 为 NSTableView 中的一行设置动画

c++ - 适用于 Mac 的免费 C++ 编译器,具有开源许可证

c++ - Xcode 4.3 在 10.7 上找不到 Carbon 库

ios - 在 iOS7 上被推送/弹出时如何禁用 View 生成的阴影?

objective-c - 为什么这种类型转换不适用于自身?

ios - 如何创建自己的完成处理程序作为方法参数的一部分

ios - NSHTTPCookie 保存错误

swift - 无法使用文件路径设置 NSImageView 的图像

xcode - XCode中没有“转到最后一个编辑位置”快捷方式吗?