首页 诗词 字典 板报 句子 名言 友答 励志 学校 网站地图
当前位置: 首页 > 教程频道 > 开发语言 > C语言 >

fopen会破坏堆内存?小弟我不相信,大侠们帮小弟我看看咋回事

2012-10-12 
fopen会破坏堆内存?我不相信,大侠们帮我看看怎么回事?项目工程采用Unicode编码测试程序:C/C++ codeTCHAR *

fopen会破坏堆内存?我不相信,大侠们帮我看看怎么回事?
项目工程采用Unicode编码
测试程序:

C/C++ code
      TCHAR * pStr = _T("A01,2,3|货位编码~可存数量~已存数量^货位编码~可存数量~已存数量^货位编码~可存数量~已存数量");    int len = _tcslen(pStr);    char * p1 = new char(len*2 + 2);    //char p1[200];    memcpy(p1, pStr, len*2);    FILE * fp = fopen("Write_File.dat", "w+b");    if (!fp) return;    fseek(fp, 0, SEEK_SET);    int n = 0;    n = fwrite(p1, sizeof(char), len*2, fp);    fseek(fp, 0, SEEK_SET);    char * p2 = new char(500);    n = fread(p2, sizeof(char), len*2, fp);    fclose(fp);        // ...


当代码单步执行到fopen这一行时(将要执行,还未执行),此时看内存监视,p1所指向的堆内存内容为(以Unicode文本查看):

然后单步执行代码fopen这一行之后,p1所指向的内容居然被改写了:


如果p1所指向的内存,不是new的,而是char p1[200];,在栈上分配内存,fopen执行之后,p1所指向的栈内存的内容就不会被改变。

这是什么情况?fopen无缘无故把我p1所指向的堆内存该篡改了?大侠们帮小弟解释解释为什么?

[解决办法]
char * p1 = new char(len*2 + 2);
你只分配了1个char 
改为 
C/C++ code
char * p1 = new char[len*2 + 2];
[解决办法]
C/C++ code
fopen supports Unicode file streams. To open a Unicode file, pass a ccs flag that specifies the desired encoding to fopen, as follows.fopen(&fp, "newfile.txt", "rw, ccs= encoding ");
[解决办法]
char * p1 = new char(len*2 + 2);
--》
char * p1 = new char[len*2 + 2];

[解决办法]
你把"Write_File.dat"和"w+b"用中间变量传递一下,看看结果有什么不同。
[解决办法]
帮顶一下吧,最好用windbg调试看看,或者别用fopen,直接用CreateFile试试
[解决办法]

[解决办法]
这个还真是容易犯得问题,记下了。

热点排行