我是C的新手,我很难理解下面的代码块不起作用的原因.
#include <stdio.h> #include <stdlib.h> int main() { char *src = "http://localhost"; /* THIS WORKS char scheme[10]; char *dp = scheme; */ //DOESN'T WORK char *dp = malloc(10); while (*src != ':') { *dp = *src; src++; dp++; } *dp = '\0'; /* WORKS puts(scheme) */ //DOESN'T WORK puts(dp); }
预期的输出是http到stdout.在这两种情况下,dp应该是指向char指针数组的指针(char **).但是在使用malloc方法时它什么都不打印.我通过GDB运行代码,我的src和dp一次被删除1个字符.如果我将while循环包含在函数调用中,它就可以工作.我认为原因是因为参数被评估为副本.但是,我读到数组是异常并作为指针传递.现在我很困惑.我可以解决这个问题,但我试图理解为什么这种方式不起作用.
解决方法
你正在循环中改变dp
dp = malloc(10);
假设dp的值为0x42000000
while () { dp++; }
假设循环变为4次,因此dp的值为0x42000004
*dp = 0;
现在你在dp指向的地址放置一个空字符
puts(dp);
然后你尝试打印那个空:)
保存dp并打印保存的值
dp = malloc(10); saveddp = dp; /* ... */ puts(saveddp); free(saveddp); /* for completeness */
它适用于scheme,因为scheme是一个数组,你不能改变那个地址!