gpt4 book ai didi

java - 本地代码深处的 FileDialog.open() 偶尔导致 JVM 崩溃

转载 作者:可可西里 更新时间:2023-11-01 11:07:29 28 4
gpt4 key购买 nike

我目前面临的是在 Windows 2008 服务器 R2 上的 Citrix 环境中运行的某些 Eclipse 应用程序中的异常访问冲突。

通话开始于org.eclipse.swt.widgets.FileDialog.open() ,调用 org.eclipse.swt.internal.win32.OS.GetSaveFileNameW 中的方法然后转到本地库。它失败了 # EXCEPTION_ACCESS_VIOLATION (0xc0000005) at pc=0x68931bab, pid=9208, tid=7616siginfo: ExceptionCode=0xc0000005, ExceptionInformation=0x00000008 0x68931bab

分析创建的小型转储,我以 thumbcache.dll 结尾

thumbcache.dll!CThumbnailCache::CThumbnailCache(int)    Unknown
thumbcache.dll!ThumbnailCacheCreateInstance(int,struct _GUID const &,void * *) Unknown
thumbcache.dll!CThumbCacheClassFactory::CreateInstance(struct IUnknown *,struct _GUID const &,void * *) Unknown
ole32.dll!CServerContextActivator::CreateInstance(IUnknown * pUnkOuter, IActivationPropertiesIn * pInActProperties, IActivationPropertiesOut * * ppOutActProperties) Line 1000 C++
ole32.dll!ActivationPropertiesIn::DelegateCreateInstance(IUnknown * pUnkOuter, IActivationPropertiesOut * * ppActPropsOut) Line 1917 C++
ole32.dll!CApartmentActivator::CreateInstance(IUnknown * pUnkOuter, IActivationPropertiesIn * pInActProperties, IActivationPropertiesOut * * ppOutActProperties) C++
ole32.dll!CProcessActivator::CCICallback(unsigned long dwContext, IUnknown * pUnkOuter, ActivationPropertiesIn * pActIn, IActivationPropertiesIn * pInActProperties, IActivationPropertiesOut * * ppOutActProperties) Line 1737 C++
ole32.dll!CProcessActivator::AttemptActivation(ActivationPropertiesIn * pActIn, IUnknown * pUnkOuter, IActivationPropertiesIn * pInActProperties, IActivationPropertiesOut * * ppOutActProperties, HRESULT (unsigned long, IUnknown *, ActivationPropertiesIn *, IActivationPropertiesIn *, IActivationPropertiesOut * *) * pfnCtxActCallback, unsigned long dwContext) Line 1630 C++
ole32.dll!CProcessActivator::ActivateByContext(ActivationPropertiesIn * pActIn, IUnknown * pUnkOuter, IActivationPropertiesIn * pInActProperties, IActivationPropertiesOut * * ppOutActProperties, HRESULT (unsigned long, IUnknown *, ActivationPropertiesIn *, IActivationPropertiesIn *, IActivationPropertiesOut * *) * pfnCtxActCallback) Line 1487 C++
ole32.dll!CProcessActivator::CreateInstance(IUnknown * pUnkOuter, IActivationPropertiesIn * pInActProperties, IActivationPropertiesOut * * ppOutActProperties) Line 1377 C++
ole32.dll!ActivationPropertiesIn::DelegateCreateInstance(IUnknown * pUnkOuter, IActivationPropertiesOut * * ppActPropsOut) Line 1917 C++
ole32.dll!CClientContextActivator::CreateInstance(IUnknown * pUnkOuter, IActivationPropertiesIn * pInActProperties, IActivationPropertiesOut * * ppOutActProperties) Line 685 C++
ole32.dll!ActivationPropertiesIn::DelegateCreateInstance(IUnknown * pUnkOuter, IActivationPropertiesOut * * ppActPropsOut) Line 1917 C++
ole32.dll!ICoCreateInstanceEx(const _GUID & Clsid, IUnknown * punkOuter, unsigned long dwClsCtx, _COSERVERINFO * pServerInfo, unsigned long dwCount, unsigned long dwActvFlags, tagMULTI_QI * pResults, ActivationPropertiesIn * pActIn) Line 1334 C++
ole32.dll!CComActivator::DoCreateInstance(const _GUID & Clsid, IUnknown * punkOuter, unsigned long dwClsCtx, _COSERVERINFO * pServerInfo, unsigned long dwCount, tagMULTI_QI * pResults, ActivationPropertiesIn * pActIn) Line 332 C++
ole32.dll!CoCreateInstanceEx(const _GUID & Clsid, IUnknown * punkOuter, unsigned long dwClsCtx, _COSERVERINFO * pServerInfo, unsigned long dwCount, tagMULTI_QI * pResults) Line 157 C++
ole32.dll!CoCreateInstance(const _GUID & rclsid, IUnknown * pUnkOuter, unsigned long dwContext, const _GUID & riid, void * * ppv) Line 110 C++
shell32.dll!_GetUIThreadThumbnailCache@8() Unknown
shell32.dll!CDefView::CreateViewWindow3(struct IShellBrowser *,struct IShellView *,unsigned long,enum FOLDERFLAGS,enum FOLDERFLAGS,enum FOLDERVIEWMODE,struct _GUID const *,struct tagRECT const *,struct HWND__ * *) Unknown
shell32.dll!CExplorerBrowser::_CreateViewWindow(struct tagRECT const *,struct HWND__ * *) Unknown
shell32.dll!CExplorerBrowser::_SwitchView(struct IShellFolder *,struct _ITEMIDLIST_ABSOLUTE const *,int) Unknown
shell32.dll!CExplorerBrowser::_BrowseToView(struct _ITEMIDLIST_ABSOLUTE const *,int) Unknown
shell32.dll!CExplorerBrowser::_BrowseObjectInternal(struct _ITEMIDLIST_RELATIVE const *,unsigned int) Unknown
shell32.dll!CExplorerBrowser::_OnBrowseObject(void) Unknown
shell32.dll!CExplorerBrowser::BrowseObject(struct _ITEMIDLIST_RELATIVE const *,unsigned int) Unknown
comdlg32.dll!CFileOpenSave::_BrowseObject(struct _ITEMIDLIST_RELATIVE const *,unsigned int) Unknown
comdlg32.dll!CFileOpenSave::_JumpToInitialLocation(void) Unknown
comdlg32.dll!CFileOpenSave::_InitOpenSaveDialog(struct HWND__ *) Unknown
comdlg32.dll!CFileOpenSave::s_OpenSaveDlgProc(struct HWND__ *,unsigned int,unsigned int,long) Unknown
user32.dll!_InternalCallWinProc@20() Unknown
user32.dll!_UserCallDlgProcCheckWow@32() Unknown
user32.dll!_DefDlgProcWorker@24() Unknown
user32.dll!_SendMessageWorker@24() Unknown
user32.dll!_InternalCreateDialog@28() Unknown
user32.dll!_InternalDialogBox@24() Unknown
user32.dll!_DialogBoxIndirectParamAorW@24() Unknown
user32.dll!_DialogBoxIndirectParamW@20() Unknown
comdlg32.dll!CFileOpenSave::Show(struct HWND__ *) Unknown
comdlg32.dll!_InvokeNewFileOpenSave(struct IFileDialog *,unsigned short,struct HWND__ *,struct _OFNINITINFO *,struct HWND__ *) Unknown
comdlg32.dll!_CreateNewFileOpenSaveInProc(unsigned short,struct HWND__ *,struct _OFNINITINFO *) Unknown
comdlg32.dll!NewGetFileName(struct OPENFILEINFO *,int) Unknown
comdlg32.dll!_NewGetSaveFileName@4() Unknown
comdlg32.dll!_GetFileName@8() Unknown
comdlg32.dll!_GetSaveFileNameW@4() Unknown

这在 hs_err_pid 中继续文件:

C  [comdlg32.dll+0x3a3c9]
C [swt-win32-3740.dll+0x7536]
j org.eclipse.swt.internal.win32.OS.GetSaveFileNameW(Lorg/eclipse/swt/internal/win32/OPENFILENAME;)Z+0
j org.eclipse.swt.internal.win32.OS.GetSaveFileName(Lorg/eclipse/swt/internal/win32/OPENFILENAME;)Z+7
j org.eclipse.swt.widgets.FileDialog.open()Ljava/lang/String;+882
[..]

VM 参数是:

jvm_args: -Dorg.eclipse.springextensionfactory.timeout=60000 -Xms128m -Xmx512m -Djava.util.Arrays.useLegacyMergeSort=true 
java_command: <unknown>
Launcher Type: generic

系统是:

---------------- 系统 ----------------

OS: Windows NT 6.1 , 64 bit Build 7601 Service Pack 1

CPU:total 32 (8 cores per cpu, 2 threads per core) family 6 model 62 stepping 4, cmov, cx8, fxsr, mmx, sse, sse2, sse3, ssse3, sse4.1, sse4.2, popcnt, avx, aes, erms, ht, tsc, tscinvbit

Memory: 4k page, physical 150912848k(141091384k free), swap 152959000k(142953452k free)

vm_info: Java HotSpot(TM) Client VM (24.51-b03) for windows-x86 JRE (1.7.0_51-b13), built on Dec 18 2013 19:09:58 by "java_re" with unknown MS VC++:1600

麻烦的是,这个问题很少发生。我们目前无法不断重现该问题。它只是不时发生。我目前的猜测是,thumbcache.dll尝试创建 ThumbnailCache 的实例,但出于某种原因不允许这样做。但是我在 Windows 领域的知识非常有限。有谁知道这个问题可能来自哪里?

最佳答案

我找到了 this错误报告似乎与您所看到的非常相似。它被标记为不会修复,但是有一个解决方法建议:

I'm going to close this as "won't fix" which simply means that we aren't going to try to work around it in swt code.

I have also added the following item to the eclipse 3.3 release notes:

Opening File Dialog crashes eclipse (Vista only)On Vista, launching eclipse using -vmargs -Xmx[any size] can crash eclipse when the FileDialog is opened. The workaround is to use the default heap size, i.e. do not use the -Xmx VM args. See bug 188317 for details.


它说“仅限 Vista”,但在发布时,Windows Server 2008 R2 甚至还不存在,所以我至少会试一试...


此错误报告中的另一条评论指出:

My error only happens when I open a FileDialog with the shell from a PopupDialog.

你的程序是这样吗?

关于java - 本地代码深处的 FileDialog.open() 偶尔导致 JVM 崩溃,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/22837730/

28 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com