問題解決——使用CriticalSection后 0xXXXXXXXX處最可能的異常: 0xC0000005: 寫入位置 0x00000014 時發生訪問沖突


================聲明=====================

本文原創,轉載請保持文章的完整性(含本聲明),並顯要的著名作者和出處。

本文鏈接:http://blog.csdn.net/wlsgzl/article/details/42003487

=========================================

電腦有一個SSD和一個HHD,SSD只有一個分區做系統盤,HHD分4個區:D、E、F、G。其中D盤放工程代碼。

還原電腦的時候,諾頓抽風,把HHD的第一分區給我還原了……這是識別錯硬盤的節奏嗎?

=========================================

結果尚未備份的一小部分小代碼沒了。於是照着以前的思路又寫了一下。

就這樣,問題來了。

=========================================

開開心心地打算看一下代碼效果,結果遇到了一個問題。

VS2010會自動在出現問題的地方停下,這是極好的。

但,可悲的是,我開了線程,出錯的是線程函數。

void CMainFrame::DealWithSlaveData(LPVOID lpVoid)
{
	//test
	CMscommWLS* pSlaveComm=(CMscommWLS*)lpVoid;

	CString strTempData;

	EnterCriticalSection(&(pSlaveComm->m_csDataRecv));	
	strTempData=pSlaveComm->m_queStrData.front();
	pSlaveComm->m_queStrData.pop();
	LeaveCriticalSection(&(pSlaveComm->m_csDataRecv));

	OutputDebugString(strTempData);
}
打上斷點跟變量,發現沒什么問題的樣子,沒有什么錯誤的指針。

於是開始搜資料。

=========================================

有用TryEnterCriticalSection版本代替EnterCriticalSection的,有添加宏取消com支持的,還有推測EnterCriticalSection嵌套的然后大家一致附和。

像這種問題都是看具體情況才能確定的,所以網上有各種各樣的回答方式,不管真假各種轉載。

大多不可信。

=========================================

想了半天,覺得還得從提示入手:最可能的異常: 0xC0000005: 寫入位置 0x00000014 時發生訪問沖突。

這位置?這個位置就是非法寫入啊。

必然是寫地址有問題。

那么只能在看下lpVoid的指針。沒什么不對的樣子,無果。

再上一步傳入這個值的地方呢?

m_TPforSlave.Start(m_CommCtrl.m_hSmpDataNeedHandle,DealWithSlaveData,this);
就是第三個參數了。

乍一看沒什么,這不是有嗎?但是這個this是誰呢?是CMainFrame*!而我要得是CMscomm*!

下面問題就好辦了,傳入指定類型的實參或者強制轉換傳入的值為正確的格式。



===============聖誕節就要到了,又要感受來自大宇宙的深深惡意了。==================





免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM