Xamarin Unified IOS WKWebView崩溃

时间:2014-10-28 12:38:58

标签: ios xamarin.ios xamarin wkwebview

我在使用带有新Xamarin Unified iOS API的WKWebView时遇到了一些麻烦,它在加载时因EXC_BAD_ACCESS(SIGABRT)而崩溃 - KERN_INVALID_ADDRESS异常(必须深入了解手机日志,视觉工作室中没有任何内容。

我希望有人对此有一些经验。以下似乎是违规代码,在经典API中运行良好(尽管由于API差异而略有变化)。如果我注释掉3个WKWebView行,以及将它添加到控制器的行,该应用程序将运行。注意:Window,Controller和WKWebView都是appdelegate类的参数。

public override bool FinishedLaunching(UIApplication app, NSDictionary options)
{
    Window = new UIWindow(UIScreen.MainScreen.Bounds);
    Window.BackgroundColor = UIColor.White;
    Window.MakeKeyAndVisible();

    Controller = new UIViewController();
    Controller.View.AutosizesSubviews = true;
    Window.RootViewController = Controller;

    var wkConfig = new WKWebViewConfiguration();
    WKWebView = new WKWebView(new CGRect(0, 20, (float)UIScreen.MainScreen.Bounds.Width, (float)UIScreen.MainScreen.Bounds.Height - 20), wkConfig);
    WKWebView.LoadRequest(new NSUrlRequest(new NSUrl(RazorRouting.GetRootUrl())));

    Controller.View.AddSubview(WKWebView);

    return true;
}

这是崩溃报告的相关部分(崩溃的线程堆栈跟踪)

Incident Identifier: 4C8B4F14-0412-48AC-A94A-70BEDFB07A07
CrashReporter Key:   35ac6193617557278e0d2ddbc984b0442b429f07
Hardware Model:      iPhone5,3
Process:             OurAppNameiOS [2311]
Path:                /private/var/mobile/Containers/Bundle/Application/003A0100-F79D-48A5-BEB5-    24CC9568E49A/OurAppNameiOS.app/OurAppNameiOS
Identifier:          com.OurApp.OurAppName
Version:             1.0 (1.0)
Code Type:           ARM (Native)
Parent Process:      launchd [1]

Date/Time:           2014-10-28 07:57:50.403 -0400
Launch Time:         2014-10-28 07:57:45.692 -0400
OS Version:          iOS 8.1 (12B411)
Report Version:      105

Exception Type:  EXC_BAD_ACCESS (SIGABRT)
Exception Subtype: KERN_INVALID_ADDRESS at 0x00000004
Triggered by Thread:  0

Thread 0 name:  Dispatch queue: com.apple.main-thread
Thread 0 Crashed:
0   libsystem_kernel.dylib          0x3766fdfc __pthread_kill + 8
1   libsystem_pthread.dylib         0x376edd32 pthread_kill + 58
2   libsystem_c.dylib               0x3760f904 abort + 72
3   OurAppNameiOS   0x00c15866 0xe1000 + 11749478
4   OurAppNameiOS   0x00c1de5c 0xe1000 + 11783772
5   libsystem_platform.dylib        0x376e9878 _sigtramp + 40
6   WebKit                          0x2d6820a6 -[WKWebView initWithFrame:configuration:] + 570
7   OurAppNameiOS   0x00bd80c0 0xe1000 + 11497664
8   OurAppNameiOS   0x00bb6ba4 0xe1000 + 11361188
9   OurAppNameiOS   0x000eb4b0 0xe1000 + 42160
10  OurAppNameiOS   0x0029d5a0 0xe1000 + 1820064
11  OurAppNameiOS   0x00c20058 0xe1000 + 11792472
12  OurAppNameiOS   0x00c5d296 0xe1000 + 12042902
13  OurAppNameiOS   0x00bf0a5c 0xe1000 + 11598428
14  OurAppNameiOS   0x00bf1584 0xe1000 + 11601284
15  UIKit                           0x2cd6c71c -[UIApplication     _handleDelegateCallbacksWithOptions:isSuspended:restoreState:] + 280
16  UIKit                           0x2cf615aa -[UIApplication     _callInitializationDelegatesForMainScene:transitionContext:] + 2354
17  UIKit                           0x2cf63af6 -[UIApplication _runWithMainScene:transitionContext:completion:] + 1370
18  UIKit                           0x2cf6e374 __84-[UIApplication _handleApplicationActivationWithScene:transitionContext:completion:]_block_invoke + 32
19  UIKit                           0x2cf62384 -[UIApplication workspaceDidEndTransaction:] + 128
20  FrontBoardServices              0x2ffcf0e6 __31-[FBSSerialQueue performAsync:]_block_invoke     + 10
21  CoreFoundation                  0x2980939a __CFRUNLOOP_IS_CALLING_OUT_TO_A_BLOCK__ + 10
22  CoreFoundation                  0x2980865c __CFRunLoopDoBlocks + 212
23  CoreFoundation                  0x29806dde __CFRunLoopRun + 758
24  CoreFoundation                  0x2975520c CFRunLoopRunSpecific + 472
25  CoreFoundation                  0x2975501e CFRunLoopRunInMode + 102
26  UIKit                           0x2cd663ea -[UIApplication _run] + 554
27  UIKit                           0x2cd611cc UIApplicationMain + 1436
28  OurAppNameiOS   0x00bd8e00 0xe1000 + 11501056
29  OurAppNameiOS   0x00bada10 0xe1000 + 11323920
30  OurAppNameiOS   0x00bad9d0 0xe1000 + 11323856
31  OurAppNameiOS   0x000ea27c 0xe1000 + 37500
32  OurAppNameiOS   0x0029d5a0 0xe1000 + 1820064
33  OurAppNameiOS   0x00c20058 0xe1000 + 11792472
34  OurAppNameiOS   0x00c5d296 0xe1000 + 12042902
35  OurAppNameiOS   0x00c60516 0xe1000 + 12055830
36  OurAppNameiOS   0x00c60354 0xe1000 + 12055380
37  OurAppNameiOS   0x00c0ead4 0xe1000 + 11721428
38  OurAppNameiOS   0x00cb18c4 0xe1000 + 12388548
39  OurAppNameiOS   0x00bf2700 0xe1000 + 11605760
40  libdyld.dylib                   0x375a9aac start + 0

1 个答案:

答案 0 :(得分:1)

这可能是由于Xamarin.iOS Unified API项目的Visual Studio构建过程中的一个错误导致特殊统一nfloat基元类型出现问题(请参阅https://bugzilla.xamarin.com/show_bug.cgi?id=23868#c14)。

我已在此处专门针对此WKWebView崩溃提交了第二个错误:https://bugzilla.xamarin.com/show_bug.cgi?id=24151。我怀疑这个新bug最终将被解决为旧bug的复制品。