jxbrowser在CountDownLatch中挂起

时间:2016-09-27 20:49:43

标签: eclipse javafx swt jxbrowser

我正在使用JavaFX将jxbrowser集成到Eclipse中,以便在SWT和jxbrowser之间架起桥梁。它常常挂起,看起来浏览器卡在等待Socket的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  

1 个答案:

答案 0 :(得分:1)

根据 Hang#1 的调用堆栈,我看到JxBrowser正在等待JavaScript代码完成执行并返回结果。这是因为你调用了Browser.executeJavaScriptAndReturnValue()函数。此函数阻止当前线程执行,并等待执行给定的JavaScript代码。

Hang#2 中的调用堆栈表示您调用Browser.canGoBack()函数,该函数向Chromium引擎发送请求,以确定我们是否可以返回并等待来自Chromium的回复。

如果 Hang#1 ,原因可能是您尝试执行的JavaScript代码。如果JavaScript代码包含无限循环,则可能需要一段时间才能完成执行。所以,请检查您执行的JavaScript代码。

如果挂起#2 ,如果您发现此功能暂停了一段时间,原因可能是死锁或Chromium引擎因某些原因而停滞不前并且没有回复(Chromium代码中可能出现死锁)。