gpt4 book ai didi

delphi - 如何解释 RtlLeaveCriticalSection 中的访问冲突

转载 作者:行者123 更新时间:2023-12-01 22:38:28 24 4
gpt4 key购买 nike

我有一个应用程序,它从表单上的计时器触发的数据库请求数据。如果出现错误(与数据库的连接丢失),我有时会收到预期的异常(EIBO_ISCError),有时我会在 ntdll.dll 的 RtlLeaveCriticalSection 中收到访问冲突。这是相应的 Eurekalog 堆栈:

------------------------------------------------------------------------------------------------------
|Adresse |Modul |Unit |Klasse |Prozedur/Methode |Zeile |
------------------------------------------------------------------------------------------------------
|Laufender Thread: ID=1320; Priorität=0; Klasse=; [Haupt Thread] |
|----------------------------------------------------------------------------------------------------|
|76FD2280|ntdll.dll | | |RtlLeaveCriticalSection | |
|76FDE0ED|ntdll.dll | | |RtlAllocateHeap | |
|76FE6CC5|ntdll.dll | | |LdrUnlockLoaderLock | |
|7552EF19|KERNELBASE.dll| | |VirtualQueryEx | |
|7552EF02|KERNELBASE.dll| | |VirtualQueryEx | |
|7552EFE6|KERNELBASE.dll| | |VirtualQuery | |
|76FC012E|ntdll.dll | | |KiUserExceptionDispatcher | |
|0069D997|Program.exe |IBODataset.pas |TIBOInternalDataset|DoHandleError |8407[23] |
|0063B3F7|Program.exe |IB_Components.pas |TIB_Session |DoHandleError |13181[2] |
|0068B36C|Program.exe |IB_Session.pas |TIB_SessionBase |HandleException |1442[58] |
|0068B03C|Program.exe |IB_Session.pas |TIB_SessionBase |HandleException |1384[0] |
|0064EE74|Program.exe |IB_Components.pas |TIB_Statement |API_Execute |22927[14]|
|0064EE10|Program.exe |IB_Components.pas |TIB_Statement |API_Execute |22913[0] |
|00655D1D|Program.exe |IB_Components.pas |TIB_Dataset |SysExecSelect |26432[1] |
|0064DA60|Program.exe |IB_Components.pas |TIB_Statement |SysExecStatement |22259[9] |
|0064D7A1|Program.exe |IB_Components.pas |TIB_Statement |SysExecute |22173[12]|
|0064D708|Program.exe |IB_Components.pas |TIB_Statement |SysExecute |22161[0] |
|00655A9F|Program.exe |IB_Components.pas |TIB_Dataset |SysExecute |26373[7] |
|00655210|Program.exe |IB_Components.pas |TIB_Dataset |SysOpen |26160[23]|
|006550F8|Program.exe |IB_Components.pas |TIB_Dataset |SysOpen |26137[0] |
|006994E5|Program.exe |IBODataset.pas |TIBODataset |DoBeforeOpen |6312[17] |
|0061FBEA|Program.exe |mvdb.pas |TImvDatabase |QueryRun |1393[10] |
...
|00B1D440|Program.exe |StartDialogForm.pas|TFormStartDialog |UpdateStartBar |494[0] |
|00B1D4C3|Program.exe |StartDialogForm.pas|TFormStartDialog |TimerExBarTimer |521[6] |
|76667BC5|USER32.dll | | |DispatchMessageA | |
|76667BBB|USER32.dll | | |DispatchMessageA | |
|00BF1178|Program.exe |Program.dpr | | |884[399] |
------------------------------------------------------------------------------------------------------

执行的代码没有什么特别的。归结为:

qry := TIBOQuery.Create(nil);      //IBObjects
qry.SQL := 'SELECT COUNT(IDX) FROM TABLE';
qry.Prepare;

创建表单时

qry.Open;       //<-- Exception
TotalCount := qry.Fields[0].AsVariant;
qry.Close;

在MDI窗体的OnTimer事件中。

DoHandleError 中调用的 IBObjects 中的代码行是

raise EIBO_ISCError.CreateISC( ... );

底层异常可能是由 qry.Open 中的数据库连接丢失引起的。我想知道的是,哪些情况(读取代码中的缺陷)会导致这种行为,有时此异常会按预期处理(Eurekalog 中的 EIBO_ISCError),有时相同的异常会导致 RtlLeaveCriticalSection 中的访问冲突。

最佳答案

看起来你有堆损坏。在某个地方,您的程序已写入您不应该写入的内存。

这可能意味着您已经写入了属于堆的关键部分数据结构,但也可能意味着您已经写入了其他位置,导致内存管理器认为存在一个实际不存在的关键部分对象。一个。

堆栈跟踪表明您仍然收到预期的常见异常,但在尝试处理该异常时,出现了问题。

您可以尝试使用调试器检查发生无效读取的位置附近的其他内存。查看程序中是否存在您识别的任何字符串或数字。它们可以指出哪一段代码写在了不该写的地方。

关于delphi - 如何解释 RtlLeaveCriticalSection 中的访问冲突,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/22630972/

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