我正在玩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
时,你可能会破坏堆栈帧,这可能会导致多种意外结果,从而不会影响程序崩溃,从而导致静默数据损坏。