to: masterz ******非常不好意思,深意还打扰您,有一问题需请教.(关于CString)******

freelybird 2002-05-21 11:41:18
我现在在维护一个比较大的工程,其中有多个DLL,由于需要,稍微加了一些功能(10行代码),
导致程序出现了一个莫名其名的问题,即Debug正常,而Release不行,退出.
这几天我一直在调试这个bug,终于找出是由于CString引起的. 后来我没办法,把整个CString
实现代码全部过一遍,查看其究竟到底是怎样实现的.
功夫不负有心人,现在取得了比较大的进展,其原因就是:
我其中有一个DLL接口函数类似这样的定义的: __declspec (dllexport) int PASCAL EXPORT test(int a, CString& strRet /*出参*/);
当调用这个函数后, 它需要赋值返回strRet = "abc";这样,在其内部,重新进行内存分配(报错),
其原因就是DLL内部的_afxPchNil的值与实际strRet的&_afxInitData值不一致,导致释放本没有分配的内存.

我想问,为什么外部的_afxPchNil与DLL里面的_afxPchNil的值不一样.而且特奇怪,只要我在程序任何地方,
加上这样一句CString("A");程序又可以正常运行.但好像系统又极不稳定.

请赐教....

...全文
82 25 打赏 收藏 转发到动态 举报
AI 作业
写回复
用AI写文章
25 条回复
切换为时间正序
请发表友善的回复…
发表回复
firmamenthy 2002-09-16
  • 打赏
  • 举报
回复
mark
Richuen22 2002-05-26
  • 打赏
  • 举报
回复
try sp5
freelybird 2002-05-26
  • 打赏
  • 举报
回复
今天下班前散分
freelybird 2002-05-26
  • 打赏
  • 举报
回复
再过30分钟就结贴.
westlingsnow 2002-05-26
  • 打赏
  • 举报
回复
是不是在test(int a, CString& strRet /*出参*/)内部使用了new char[xxx],然后用strcpy或strncpy、memcpy等函数赋值给CString类的?这种问题我也遇到过的!
nlxx 2002-05-26
  • 打赏
  • 举报
回复
up
freelybird 2002-05-24
  • 打赏
  • 举报
回复
非常不好意思,昨天下午有事,提前下班了,所以没结贴.
今天写一篇关于CString的总结,也对该问题进行了分析解答.
请浏览:
http://www.csdn.net/expert/topic/749/749795.xml?temp=.168667
http://www.csdn.net/expert/topic/749/749810.xml?temp=.4293024
alphapiao 2002-05-23
  • 打赏
  • 举报
回复
先UP一下抢点分再说^v^
freelybird 2002-05-23
  • 打赏
  • 举报
回复
今天下班前散分
kenryHuang 2002-05-23
  • 打赏
  • 举报
回复
准备学习中..
akademecia 2002-05-23
  • 打赏
  • 举报
回复
告诉我们原因吧!
freelybird 2002-05-23
  • 打赏
  • 举报
回复
up者有分
freelybird 2002-05-23
  • 打赏
  • 举报
回复
哈哈...
原因终于找到了,不过现在没时间详细解释,我打算这几天对CString做一个全面的总结,以把自己的经验供大家供考.

各位有何意见,讨论者都有分.
有精辟分析者更是高分相送.
Hover 2002-05-22
  • 打赏
  • 举报
回复
...
freelybird 2002-05-22
  • 打赏
  • 举报
回复
#define extern __declspec( selectany ) AFX_STATIC_DATA

AFX_STATIC_DATA int _afxInitData[] = { -1, 0, 0, 0 };
AFX_STATIC_DATA CStringData* _afxDataNil = (CStringData*)&_afxInitData;

在msdn上说,加了这样的__declspec(selectany)修饰符,在DLL及EXE中只会初始化一次,而且是全局外连的,
但现在两个地方的地址不一样.

谁知道,再加200分(讨论者也可加分).
freelybird 2002-05-22
  • 打赏
  • 举报
回复
to: comet(二子乘舟)
我传的是引用,即指针(换说没关系),除非你完全抛弃CString,否则你转换为LPTSTR也一样有问题.
freelybird 2002-05-22
  • 打赏
  • 举报
回复
对于有些由于内存引发的异常,我们可以捕获它并设法挽回它.

但现在的问题是,我已确切地知道错误的地方,可我却没办法知道它为什么会这样?

实际上是这样的:
CString a;
a = "test"; //假如它在同一EXE模块中,现在没问题.

但是,这样即不行,而且原来的代码没问题
CString a;
DllTest(a);

__declspec (dllexport) int PASCAL EXPORT DllTest(CString& strRet)//接口函数
{
strRet = "test";
}

我分析,肯定是那块地方对它产生了影响.
comet 2002-05-22
  • 打赏
  • 举报
回复
DLL中得到的_afxPchNil与在调用它的EXE文件不一样可能是他们使用了不同的run-time library,又或者是因为使用了不同的预定义宏,导致CString类在dll和exe中的结构并不一样。


我觉得DLL接口函数中最好只使用简单类型。不要用CString,用LPTSTR代替!
masterz 2002-05-22
  • 打赏
  • 举报
回复
no, my code is just simular to that. Only assign new string value to it, it seems that if I declare several CString variable, then only the first few works well, but some others fail. the string assigned to it is not long string, less than 100 chars!
I don't know what is wrong with my code or your code, sorry. In fact I also see some one else complained on CString before in csdn, vc page.
masterz 2002-05-22
  • 打赏
  • 举报
回复
http://www.cuj.com/experts/1906/alexandr.htm
you may get some idea about the trouble with COW strings
加载更多回复(5)

16,548

社区成员

发帖
与我相关
我的任务
社区描述
VC/MFC相关问题讨论
社区管理员
  • 基础类社区
  • AIGC Browser
  • encoderlee
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告

        VC/MFC社区版块或许是CSDN最“古老”的版块了,记忆之中,与CSDN的年龄几乎差不多。随着时间的推移,MFC技术渐渐的偏离了开发主流,若干年之后的今天,当我们面对着微软的这个经典之笔,内心充满着敬意,那些曾经的记忆,可以说代表着二十年前曾经的辉煌……
        向经典致敬,或许是老一代程序员内心里面难以释怀的感受。互联网大行其道的今天,我们期待着MFC技术能够恢复其曾经的辉煌,或许这个期待会永远成为一种“梦想”,或许一切皆有可能……
        我们希望这个版块可以很好的适配Web时代,期待更好的互联网技术能够使得MFC技术框架得以重现活力,……

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