fopen会破坏堆内存?小弟我不相信,大侠们帮小弟我看看咋回事
fopen会破坏堆内存?我不相信,大侠们帮我看看怎么回事?
项目工程采用Unicode编码
测试程序:
当代码单步执行到fopen这一行时(将要执行,还未执行),此时看内存监视,p1所指向的堆内存内容为(以Unicode文本查看):
然后单步执行代码fopen这一行之后,p1所指向的内容居然被改写了:
如果p1所指向的内存,不是new的,而是char p1[200];,在栈上分配内存,fopen执行之后,p1所指向的栈内存的内容就不会被改变。
这是什么情况?fopen无缘无故把我p1所指向的堆内存该篡改了?大侠们帮小弟解释解释为什么?
------解决方案--------------------
char * p1 = new char(len*2 + 2);
你只分配了1个char
改为
项目工程采用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试试
------解决方案--------------------
------解决方案--------------------
这个还真是容易犯得问题,记下了。