我的代码有效,但我不太明白为什么 . 我正在分配一个带字符串的指针,将该字符串传递给一个函数,然后对其进行修改 . 我很困惑,即使输入的字符串远远大于原始字符串,它似乎运行正常 . 我希望它抱怨覆盖内存,特别是因为原始指针不是MALLOC / CALLOCed .
void changeArray(char *(*anArray)[3]);
功能声明
char *testArray[] = { "This is a test", "A Second Test", "A Third Test" };
指针声明和初始化
changeArray(&testArray);
功能调用
void changeArray(char *(*anArray)[3]){
char userName[200];
printf("What is your name?:\t");
scanf("%199[^\n]s", userName);
*anArray[0] = userName; }
功能
printf("Your name is: %s\n", testArray[0]);
将结果打印在main中 .
为什么testArray [0]能够接受新字符串而不为其重新分配内存?更令人费解的是,我正在看当地人的结果并且它看起来已损坏,但仍打印得很好 .
+ [0] 0x00e2f850 "D`\x3\x1 øâ" char *
我知道询问工作代码是很奇怪的,但我需要确保我理解发生了什么,以便我可以在以后正确实现/避免它 .