我正在使用JavaFX将jxbrowser集成到Eclipse中,以便在SWT和jxbrowser之间架起桥梁。它经常挂起,它看起来像是浏览器卡在countDownLatch中等待套接字。有人知道问题出在哪里吗?任何帮助都将不胜感激。谢谢!
以下是两个挂起的堆栈跟踪:
挂起#1
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 挂起#2
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 发布于 2016-09-28 18:19:22
根据Hang #1的调用堆栈,我看到JxBrowser正在等待JavaScript代码完成执行并返回结果。这是因为您调用了Browser.executeJavaScriptAndReturnValue()函数。此函数阻止当前线程执行并等待,直到执行给定的JavaScript代码。
Chromium挂起#2中的调用堆栈指示您调用Browser.canGoBack()函数,该函数向Chromium引擎发送请求,以确定我们是否可以返回并等待Chromium的回复。
在挂起#1的情况下,原因可能是在您试图执行的JavaScript代码中。如果JavaScript代码包含无限循环,则可能需要一段时间才能完成执行。因此,请检查您执行的JavaScript代码。
在Chromium挂起#2的情况下,如果你看到这个函数被卡住了一段时间,原因可能是死锁,或者是Chromium引擎因为某种原因卡住了而没有回复(可能是Chromium代码中的死锁)。
https://stackoverflow.com/questions/39734071
复制相似问题