CString使用(多线程、线程安全)

 

CString的线程安全问题

在多线程中使用一个局部CString变量相加时发现相加的结果是后一个字符串值,没有时间过多研究,只好改成了char*,不过如下方法也可以避免:
CWin32Heap stringHeap( HEAP_NO_SERIALIZE, 0, 0 );
CAtlStringMgr stringMgr( &stringHeap );
CString strstate(&stringMgr );

找了一些资料贴上来希望对过客有用:
http://www.cppblog.com/alantop/archive/2008/07/10/55786.html

 

 

讨论CString线程安全性问题(内存泄漏)

 

 

CString在线程处理中,稍有处理不当,极易引起内存泄漏。
让我们来看一个例子:
在线程函数中使用如下代码

 

 

CString strstate;    
strstate.Format("正在统计中... (共 %d 项)", p->m_nItem);


可以看到非常简单,在debug下,很容易看到如下的内存泄漏。



怎么回事?
先把修改好的代码放上来

CWin32Heap stringHeap( HEAP_NO_SERIALIZE, 0, 0);
CAtlStringMgr stringMgr( &stringHeap );
CString strstate(&stringMgr );
strstate.Format("正在统计中... (共 %d 项)", p->m_nItem);

如上代码才具有线程安全性。
http://msdn.microsoft.com/zh-cn/library/cc485480(VS.71).aspx

 

 

 

 

 

 

 

 

 

 

 

 

 

参考链接:http://blog.csdn.net/wu_123_456/article/details/37649663

                    http://www.cppblog.com/elva/archive/2008/12/22/70076.html

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值