#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 = 'dp = malloc(10);'; /* WORKS puts(scheme) */ //DOESN'T WORK puts(dp);}
预期的输出是http到stdout.在这两种情况下,dp应该是指向char指针数组的指针(char **).但是在使用malloc方法时它什么都不打印.我通过GDB运行代码,我的src和dp一次被删除1个字符.如果我将while循环包含在函数调用中,它就可以工作.我认为原因是因为参数被评估为副本.但是,我读到数组是异常并作为指针传递.现在我很困惑.我可以解决这个问题,但我试图理解为什么这种方式不起作用.
解决方法 你正在循环中改变dpwhile () { dp++;}
假设dp的值为0x42000000
*dp = 0;
假设循环变为4次,因此dp的值为0x42000004
puts(dp);
现在你在dp指向的地址放置一个空字符
dp = malloc(10);saveddp = dp;/* ... */puts(saveddp);free(saveddp); /* for completeness */
然后你尝试打印那个空:)
保存dp并打印保存的值
它适用于scheme,因为scheme是一个数组,你不能改变那个地址!
总结以上是内存溢出为你收集整理的C char指针vs指向char数组的指针,增加动态分配全部内容,希望文章能够帮你解决C char指针vs指向char数组的指针,增加动态分配所遇到的程序开发问题。
如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)