#include <stdio.h>
#include <WINDOWS.H>
void main()
{
char *p = NULL;
p = new char[1024*1024*1024*1024]; //分配1T内存,居然还能成功??
memcpy(p,"123456",6);
}
这段代码 new居然能成功,
1024*1024*1024*1024发生上溢
高位的1丢弃后,其实就是0 p指向一个0字节长度的数组
memcpy(p,"123456",6);
这里其实越界了
1024^4是13位,越界了吧
你试试把方括号里的数改成1<<30,看看行不行。(1<<30==2^30)
new的时候并没有给你真正的分配内存。
只要在你要访问的时候才会真正的给你分配内存、