From d7c88780e1df54f34563d60bd7fa01011d2eef03 Mon Sep 17 00:00:00 2001
From: chenluhua1980 <Chenluhua@qq.com>
Date: 星期一, 26 一月 2026 23:17:17 +0800
Subject: [PATCH] 1.CSVData.cpp 里 unserialize 用了 8*2、125*2,但 serialize 只写 8 + 125 字节。 m_svRawData.insert 的 end 指针是 pszBuffer + 125*2,没有用 index 计算,可能把无效区域一起拷进去。 一旦 size 实际是 133(不是 266),就会直接越界,堆会被破坏,m_svDatas.clear() 在销毁元素时崩。
---
SourceCode/Bond/EAPSimulator/EAPSimulator.cpp | 26 ++++++++++++++++++++++++++
1 files changed, 26 insertions(+), 0 deletions(-)
diff --git a/SourceCode/Bond/EAPSimulator/EAPSimulator.cpp b/SourceCode/Bond/EAPSimulator/EAPSimulator.cpp
index b7eb5b5..52d469b 100644
--- a/SourceCode/Bond/EAPSimulator/EAPSimulator.cpp
+++ b/SourceCode/Bond/EAPSimulator/EAPSimulator.cpp
@@ -71,6 +71,24 @@
// 渚嬪淇敼涓哄叕鍙告垨缁勭粐鍚�
SetRegistryKey(_T("搴旂敤绋嬪簭鍚戝鐢熸垚鐨勬湰鍦板簲鐢ㄧ▼搴�"));
+
+ // 鏈▼搴忔枃浠剁洰褰�
+ TCHAR sDrive[_MAX_DRIVE];
+ TCHAR sDir[_MAX_DIR];
+ TCHAR sFilename[_MAX_FNAME], sAppFilename[_MAX_FNAME];
+ TCHAR sExt[_MAX_EXT];
+ GetModuleFileName(AfxGetInstanceHandle(), sAppFilename, _MAX_FNAME);
+ _tsplitpath_s(sAppFilename, sDrive, sDir, sFilename, sExt);
+ m_strAppDir = CString(sDrive) + CString(sDir);
+ m_strAppFile = CString(sFilename);
+
+
+ // 鍒濆鍖朢x搴�
+ RX_Init();
+ HSMS_Initialize();
+
+
+
CEAPSimulatorDlg dlg;
m_pMainWnd = &dlg;
INT_PTR nResponse = dlg.DoModal();
@@ -105,3 +123,11 @@
return FALSE;
}
+
+int CEAPSimulatorApp::ExitInstance()
+{
+ HSMS_Term();
+ RX_Term();
+
+ return CWinApp::ExitInstance();
+}
--
Gitblit v1.9.3