يتم إلغاء تنشيط نقاط التوقف في Xcode: exc_bad_access عندما nszombieenabled == نعم

StackOverflow https://stackoverflow.com/questions/1393788

سؤال

هذا السؤال عفا عليه الزمن بعيد ، حيث تم طلب Xcode 3. من فضلك لا تعتبره مفيدًا لـ Xcode 4+. =)


تعطل تطبيقي في الأحداث العشوائية (على ما يبدو). لذلك ، أردت إضافة nszombieenabled لتصحيح تطبيق iPhone الخاص بي. لقد قمت باستنساخ هدفي وقمت بتعيين info.plist على نفس الهدف الأصلي وضبط nszombieenabled على نعم.

بمجرد أن أقوم بتشغيل التطبيق ، يتعطل مع تتبع مكدس ...

#0  0x3025db0c in ___forwarding___ ()
#1  0x30239db2 in __forwarding_prep_0___ ()
#2  0x304f5105 in NSPopAutoreleasePool ()
#3  0x308ee452 in _UIApplicationHandleEvent ()
#4  0x32031425 in PurpleEventCallback ()
#5  0x30235253 in CFRunLoopRunSpecific ()
#6  0x302343c8 in CFRunLoopRunInMode ()
#7  0x308e6209 in -[UIApplication _run] ()
#8  0x308eef81 in UIApplicationMain ()
#9  0x000023ef in main (argc=1, argv=0xbffff0bc) at /Users/tomen/Documents/MIB-Sprint4/main.m:26

يحدث هذا فقط عندما يتم تعيين nszombieenabled على نعم. إذا لم يتم تعيينه ، فإن التطبيق يعمل فقط (ويتعطل في أوقات مختلفة)

كنت أرغب في إضافة نقاط توقف مثل "-[_ nszombie methodsignatureforselector:] وغيرها ، لكنهم يتم إلغاء تنشيطه أثناء تصحيح الأخطاء. لقد جربته في كلا الاتجاهين مع "تحميل رموز بتكس".

حاولت أيضًا تعيين ملف ~/.gdbinit

fb -[NSException raise]
fb -[NSAssertionHandler handleFailureInFunction:file:lineNumber:description:]
fb -[NSAssertionHandler handleFailureInMethod:object:file:lineNumber:description:]

#define NSZombies
# this will give you help messages.  Set to NO to turn them off.
set env MallocHelp=YES
# might also be set in launch arguments.
set env NSZombieEnabled=YES
set env NSDeallocateZombies=NO
set env MallocCheckHeapEach=100000
set env MallocCheckHeapStart=100000
set env MallocScribble=YES
set env MallocGuardEdges=YES
set env MallocCheckHeapAbort=1

set env CFZombie 5

fb -[_NSZombie init]
fb -[_NSZombie retainCount]
fb -[_NSZombie retain]
fb -[_NSZombie release]
fb -[_NSZombie autorelease]
fb -[_NSZombie methodSignatureForSelector:]
fb -[_NSZombie respondsToSelector:]
fb -[_NSZombie forwardInvocation:]
fb -[_NSZombie class]
fb -[_NSZombie dealloc]

fb szone_error

التي تنتج هذه النتيجة في وحدة التحكم:

The Debugger has exited with status 0.
[Session started at 2009-09-08 13:48:40 +0200.]
Loading program into debugger…
GNU gdb 6.3.50-20050815 (Apple version gdb-966) (Tue Mar 10 02:43:13 UTC 2009)
Copyright 2004 Free Software Foundation, Inc.
GDB is free software, covered by the GNU General Public License, and you are
welcome to change it and/or distribute copies of it under certain conditions.
Type "show copying" to see the conditions.
There is absolutely no warranty for GDB.  Type "show warranty" for details.
This GDB was configured as "i386-apple-darwin".warning: Unable to read symbols for "/System/Library/Frameworks/UIKit.framework/UIKit" (file not found).
warning: Unable to read symbols from "UIKit" (not yet mapped into memory).
warning: Unable to read symbols for "/System/Library/Frameworks/CoreGraphics.framework/CoreGraphics" (file not found).
warning: Unable to read symbols from "CoreGraphics" (not yet mapped into memory).
Pending breakpoint 1 - "-[NSException raise]" resolved
Pending breakpoint 2 - "-[NSAssertionHandler handleFailureInFunction:file:lineNumber:description:]" resolved
Pending breakpoint 3 - "-[NSAssertionHandler handleFailureInMethod:object:file:lineNumber:description:]" resolved
Pending breakpoint 14 - "szone_error" resolved
Program loaded.
sharedlibrary apply-load-rules all
Attaching to program: `/Users/tomen/Library/Application Support/iPhone Simulator/User/Applications/F77D9D82-0B34-4B8D-9076-AE883A2714F4/MIB.app/MIB', process 279.
Re-enabling shared library breakpoint 1
Re-enabling shared library breakpoint 2
Re-enabling shared library breakpoint 3
Re-enabling shared library breakpoint 14
Re-enabling shared library breakpoint 16
Re-enabling shared library breakpoint 17
Re-enabling shared library breakpoint 18
warning: Couldn't raise load state for requested objfile: "/System/Library/Frameworks/CoreFoundation.framework/Versions/A/CoreFoundation" for breakpoint 1/

warning: Couldn't raise load state for requested objfile: "/System/Library/Frameworks/Foundation.framework/Versions/C/Foundation" for breakpoint 2/

warning: Couldn't raise load state for requested objfile: "/System/Library/Frameworks/Foundation.framework/Versions/C/Foundation" for breakpoint 3/

لماذا يتم إلغاء تنشيط نقاط التوقف الخاصة بي؟

هل كانت مفيدة؟

المحلول

لقد كنت أحاول هذا النهج أيضًا مع نفس النتائج. ما أفهمه هو أن نقاط التوقف عن NSZOMBIE لم تعد صالحة في الفهد والثلوج.

بعض البدائل:

1) تفريغ سجل EAX على OBJ_MSG_SEND. لم أحاول هذا الشخصي شخصيًا ، لكنني وجدت العديد من المنشورات حول هذا الموضوع:كيفية تصحيح exc_bad_access التي تحدث فقط على هدف الإصدار لتطبيق iPhone؟

2) استخدام المعلومات malloc-تاريخ. يعمل بشكل جيد في جهاز المحاكاة ، لكنني لم أحصل على القليل من الحظ في الحصول على سجلات الجهاز.العثور على مثيلات محررة من الأشياء

3) ربما يكون أفضل شيء القيام به هو تشغيل تطبيقك في الأدوات. لاحظ أن وضع nszombie غير متوفر على الجهاز. قد يكون هذا مفيدًا:iPhone Memory Debug Nszombie

مرخصة بموجب: CC-BY-SA مع الإسناد
لا تنتمي إلى StackOverflow
scroll top