我正在使用JavaFX将jxbrowser集成到Eclipse中,以便在SWT和jxbrowser之间架起桥梁。它常常挂起,看起来浏览器卡在等待Socket的countDownLatch中。任何人都知道问题是什么?任何帮助将非常感谢。谢谢!
以下是两个挂起的堆栈跟踪:
Unsafe.park(boolean, long) line: not available [native method]
LockSupport.parkNanos(Object, long) line: not available
CountDownLatch$Sync(AbstractQueuedSynchronizer).doAcquireSharedNanos(int, long) line: not available
CountDownLatch$Sync(AbstractQueuedSynchronizer).tryAcquireSharedNanos(int, long) line: not available
CountDownLatch.await(long, TimeUnit) line: not available
LatchUtil.await(CountDownLatch, RuntimeException, int) line: 25
LatchUtil.await(CountDownLatch, RuntimeException) line: 20
SocketChannel.post(T) line: 189
Browser.executeJavaScriptAndReturnValue(long, String) line: 1643
Unsafe.park(boolean, long) line: not available [native method]
LockSupport.parkNanos(Object, long) line: not available
CountDownLatch$Sync(AbstractQueuedSynchronizer).doAcquireSharedNanos(int, long) line: not available
CountDownLatch$Sync(AbstractQueuedSynchronizer).tryAcquireSharedNanos(int, long) line: not available
CountDownLatch.await(long, TimeUnit) line: not available
LatchUtil.await(CountDownLatch, RuntimeException, int) line: 25
LatchUtil.await(CountDownLatch, RuntimeException) line: 20
SocketChannel.post(T) line: 189
Browser.b(M) line: 274
Browser.canGoBack() line: 1818
答案 0 :(得分:1)
根据 Hang#1 的调用堆栈,我看到JxBrowser正在等待JavaScript代码完成执行并返回结果。这是因为你调用了Browser.executeJavaScriptAndReturnValue()函数。此函数阻止当前线程执行,并等待执行给定的JavaScript代码。
Hang#2 中的调用堆栈表示您调用Browser.canGoBack()函数,该函数向Chromium引擎发送请求,以确定我们是否可以返回并等待来自Chromium的回复。
如果 Hang#1 ,原因可能是您尝试执行的JavaScript代码。如果JavaScript代码包含无限循环,则可能需要一段时间才能完成执行。所以,请检查您执行的JavaScript代码。
如果挂起#2 ,如果您发现此功能暂停了一段时间,原因可能是死锁或Chromium引擎因某些原因而停滞不前并且没有回复(Chromium代码中可能出现死锁)。