C char指针vs指向char数组的指针,增加动态分配

前端之家收集整理的这篇文章主要介绍了C char指针vs指向char数组的指针,增加动态分配前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
我是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是一个数组,你不能改变那个地址!

猜你在找的C&C++相关文章