我正在玩C++,我意识到指针数组和常规数组之间存在显着差异.
char *myString1 = new char[1]; char myString2 [3]; myString1[0] = 'a'; myString1[1] = 'b'; myString1[2] = 'c'; myString1[3] = 'd'; myString2[0]='a'; myString2[1]='b'; myString2[2]='c'; myString2[3]='d';
我很困惑为什么myString1编译甚至用简单的for循环打印每个字符都没有问题,即使我只是初始化初始大小为1.
但是,myString2似乎给了我编译错误,因为我初始化了一个超出数组边界的值.
两者都应该导致未定义的行为.你绝对应该避免走出界限.
但请注意,这两个阵列位于不同的内存区域. myString1
,在运行时动态分配,驻留在免费存储(或堆)中.
myString2
另一方面,编译器保留其空间,可以是自动存储,也可以是静态存储.您的示例表明您正在使用自动存储,在大多数常见PC中,自动存储位于程序堆栈中.因此,当你陷入困境时myString2
,你可能会破坏堆栈帧,这可能会导致多种意外结果,从而不会影响程序崩溃,从而导致静默数据损坏.