我在这里遇到同样的崩溃情况。
如果您使用 xulrunner 10.0.4esr,您会在 JVM 中止之前获得此 System.err 输出:
###!!! ABORT: Main-thread-only object used off the main thread: file e:/builds/moz2_slave/rel-m-esr10-xr-w32-bld/build/xpcom/base/nsCycleCollector.cpp, line 1278
我发现你需要销毁 nsIWebBrowser 实例的 nsIBaseWindow 来清理东西:
nsIWebBrowser webBrowser = (nsIWebBrowser)b.getWebBrowser();
nsIBaseWindow baseWindow = (nsIBaseWindow)webBrowser.queryInterface(nsIBaseWindow.NS_IBASEWINDOW_IID);
baseWindow.destroy();
这样做之后,您可以在其中创建带有 Mozilla / xul 的 SWT 浏览器的新实例。
问题是,您不能再访问 nsInterfaces(因为 Browser.getWebBrowser() 返回 null)!
有没有办法在 xulrunner 10 或 24 上以编程方式访问该 nsIBaseWindow 对象?
这是崩溃日志的片段(使用 xulrunner 24 和 JDK6 运行时生成):
Native frames: (J=compiled Java code, j=interpreted, Vv=VM code, C=native code)
C [xul.dll+0xaa1b4c] NS_CycleCollectorSuspect2+0xc
C [xul.dll+0x6d45d1] xpc_ActivateDebugMode+0x1a588
C [xul.dll+0x6d1192] xpc_ActivateDebugMode+0x17149
C [xul.dll+0xa74003] JSD_GetValueForObject+0x2b8625
C [xul.dll+0xa72ffa] JSD_GetValueForObject+0x2b761c
C [xul.dll+0x70fdae] xpc_ActivateDebugMode+0x55d65
C [xul.dll+0x711bc6] xpc_ActivateDebugMode+0x57b7d
C [swt-xulrunner-win32-4426.dll+0x11d6] Java_org_eclipse_swt_internal_mozilla_XPCOM__1VtblCall__II+0xe
j org.eclipse.swt.internal.mozilla.XPCOM.VtblCall(II)I+9
j org.eclipse.swt.internal.mozilla.nsIBaseWindow.Create()I+9
j org.eclipse.swt.browser.MozillaDelegate.createBaseWindow(Lorg/eclipse/swt/internal/mozilla/nsIBaseWindow;)I+1
j org.eclipse.swt.browser.Mozilla.initWebBrowserWindows()V+184
j org.eclipse.swt.browser.Mozilla.create(Lorg/eclipse/swt/widgets/Composite;I)V+665
j org.eclipse.swt.browser.Browser.<init>(Lorg/eclipse/swt/widgets/Composite;I)V+81
j XulTest$1.run()V+47