质疑MFC中的线程局部存储代码

FanTasyCC 2012-11-18 05:16:05

CNoTrackObject* CThreadLocalObject::GetData(CNoTrackObject* (*pfnCreateObject)())
{ if(m_nSlot == 0)
{ if(_afxThreadData == NULL)
_afxThreadData = new(__afxThreadData) CThreadSlotData;
m_nSlot = _afxThreadData->AllocSlot();
}
CNoTrackObject* pValue = (CNoTrackObject*)_afxThreadData->GetThreadValue(m_nSlot);
if(pValue == NULL)
{ // 创建一个对象,此对象的成员会被初始化为0
pValue = (*pfnCreateObject)();
// 使用线程私有数据保存新创建的对象
_afxThreadData->SetValue(m_nSlot, pValue);
}
return pValue;
}


多个线程进入会存在多次调用_afxThreadData = new(__afxThreadData) CThreadSlotData;
由于afxThreadData是全局变量,这里有线程安全问题?
...全文
186 2 打赏 收藏 转发到动态 举报
写回复
用AI写文章
2 条回复
切换为时间正序
请发表友善的回复…
发表回复
  • 打赏
  • 举报
回复
在进入winmain之前,mfc内部已经调用一次了。 你写的创建线程的代码都在mfc内部调用之后,所以没有线程安全问题。
javamy023 2012-12-25
  • 打赏
  • 举报
回复
我只是来围观一下!!

703

社区成员

发帖
与我相关
我的任务
社区描述
C++ Builder ActiveX/COM/DCOM
社区管理员
  • ActiveX/COM/DCOM社区
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧