测试程序:
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所指向的堆内存该篡改了?大侠们帮小弟解释解释为什么?