2013-07-31 11 views
5

Pracuję nad moją pierwszą prawdziwą aplikacją przy użyciu Xamarin.IOS. Większość czasu aplikacja działa świetnie, ale kilka razy dziennie to wywala się z następującym stacktrace:Znaleźć przyczynę SIGSEGV w aplikacji Xamarin.iOS

mono-rt: Stacktrace: 
mono-rt: at <unknown> <0xffffffff> 
mono-rt: at (wrapper managed-to-native) MonoTouch.Foundation.NSObject.monotouch_release_managed_ref (intptr) <IL 0x00023, 0xffffffff> 
mono-rt: at MonoTouch.Foundation.NSObject.ReleaseManagedRef() [0x00000] in /Developer/MonoTouch/Source/monotouch/src/Foundation/NSObject.cs:98 
mono-rt: at MonoTouch.Foundation.NSObject/NSObject_Disposer.Drain (MonoTouch.Foundation.NSObject) [0x00062] in /Developer/MonoTouch/Source/monotouch/src/shared/Foundation/NSObject2.cs:545 
mono-rt: at (wrapper runtime-invoke) <Module>.runtime_invoke_void_object (object,intptr,intptr,intptr) <IL 0x00050, 0xffffffff> 
mono-rt: at <unknown> <0xffffffff> 
mono-rt: at (wrapper managed-to-native) MonoTouch.UIKit.UIApplication.UIApplicationMain (int,string[],intptr,intptr) <IL 0x0009f, 0xffffffff> 
mono-rt: at MonoTouch.UIKit.UIApplication.Main (string[],string,string) [0x0004c] in /Developer/MonoTouch/Source/monotouch/src/UIKit/UIApplication.cs:38 
mono-rt: at Diet52App.Application.Main (string[]) [0x00008] in /Users/danielnordmark/Projects/Diet52App/Diet52App/Main.cs:16 
mono-rt: at (wrapper runtime-invoke) <Module>.runtime_invoke_void_object (object,intptr,intptr,intptr) <IL 0x00050, 0xffffffff> 

mono-rt: 
Native stacktrace: 


mono-rt: 
================================================================= 
Got a SIGSEGV while executing native code. This usually indicates 
a fatal error in the mono runtime or one of the native libraries 
used by your application. 
================================================================= 

Domyślam się, że jakiś obiekt dostanie śmieci zebranych przed staram się go używać. Ale czuję się trochę zagubiony, jak dowiedzieć się, kiedy i gdzie w moim kodzie to się dzieje.

Jak mogę się dowiedzieć, gdzie jest problem? Każda pomoc jest doceniana!

Odpowiedz

4

Problem wydawał się być związany z moim UITableViewController, miałem klasę bazową i dwie różne instancje. Konflikt między tymi dwoma powodował błąd SIGSEGV.

udało mi się śledzić ten problem dzięki tej odpowiedzi https://stackoverflow.com/a/6769885/248905

Jedyna modyfikacja musiałem zrobić było zawinąć kod z InvokeOnMainThread jak ta,

Aktualizacja: zaktualizowałem moją rozwiązanie po Miałem kontakt z Rolfem na Xamarinie, poprawną poprawką jest umieszczenie kodu w ViewDidDissapear zamiast Dispose.

public override void ViewDidDisappear (bool animated) 
{ 
    searchController.SearchResultsSource = null; 
    searchController.Delegate = null; 
    base.ViewDidDisappear (animated); 
} 
Powiązane problemy