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/Servo/CSlot.h | 10 ++++++++++ 1 files changed, 10 insertions(+), 0 deletions(-) diff --git a/SourceCode/Bond/Servo/CSlot.h b/SourceCode/Bond/Servo/CSlot.h index f7445aa..d1869fc 100644 --- a/SourceCode/Bond/Servo/CSlot.h +++ b/SourceCode/Bond/Servo/CSlot.h @@ -27,7 +27,15 @@ void setName(const char* pszName); BOOL isEmpty(); CContext* getContext(); + CContext* getTempContext(); void setContext(CContext* pContext); + void setLinkSignalPath(int path); + int getLinkSignalPath(); + void serialize(CArchive& ar); + + private: + void WriteString(CArchive& ar, std::string& string); + void ReadString(CArchive& ar, std::string& string); private: int m_nPosition; @@ -35,8 +43,10 @@ MaterialsType m_materialsType; std::string m_strName; CContext* m_pContext; + CContext* m_pTempContext; BOOL m_bEnable; BOOL m_bLock; + int m_nLinkSignalPath; }; } -- Gitblit v1.9.3