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

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试试
------解决方案--------------------

------解决方案--------------------
这个还真是容易犯得问题,记下了。