Error[8]: Undefined offset: 6, File: /www/wwwroot/outofmemory.cn/tmp/plugin_ss_superseo_model_superseo.php, Line: 121
File: /www/wwwroot/outofmemory.cn/tmp/plugin_ss_superseo_model_superseo.php, Line: 473, decode(

概述我是C的新手,我很难理解下面的代码块不起作用的原因. #include <stdio.h>#include <stdlib.h>int main(){ char *src = "http://localhost"; /* THIS WORKS char scheme[10]; char *dp = scheme; */ // 我是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 = '
dp = malloc(10);
'; /* WORKS puts(scheme) */ //DOESN'T WORK puts(dp);}

预期的输出是http到stdout.在这两种情况下,dp应该是指向char指针数组的指针(char **).但是在使用malloc方法时它什么都不打印.我通过GDB运行代码,我的src和dp一次被删除1个字符.如果我将while循环包含在函数调用中,它就可以工作.我认为原因是因为参数被评估为副本.但是,我读到数组是异常并作为指针传递.现在我很困惑.我可以解决这个问题,但我试图理解为什么这种方式不起作用.

解决方法 你正在循环中改变dp
while () {    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数组的指针,增加动态分配所遇到的程序开发问题。

如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。

)
File: /www/wwwroot/outofmemory.cn/tmp/route_read.php, Line: 126, InsideLink()
File: /www/wwwroot/outofmemory.cn/tmp/index.inc.php, Line: 165, include(/www/wwwroot/outofmemory.cn/tmp/route_read.php)
File: /www/wwwroot/outofmemory.cn/index.php, Line: 30, include(/www/wwwroot/outofmemory.cn/tmp/index.inc.php)
C char指针vs指向char数组的指针,增加动态分配_C_内存溢出

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

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

概述我是C的新手,我很难理解下面的代码块不起作用的原因. #include <stdio.h>#include <stdlib.h>int main(){ char *src = "http://localhost"; /* THIS WORKS char scheme[10]; char *dp = scheme; */ // 我是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 = '
dp = malloc(10);
'; /* WORKS puts(scheme) */ //DOESN'T WORK puts(dp);}

预期的输出是http到stdout.在这两种情况下,dp应该是指向char指针数组的指针(char **).但是在使用malloc方法时它什么都不打印.我通过GDB运行代码,我的src和dp一次被删除1个字符.如果我将while循环包含在函数调用中,它就可以工作.我认为原因是因为参数被评估为副本.但是,我读到数组是异常并作为指针传递.现在我很困惑.我可以解决这个问题,但我试图理解为什么这种方式不起作用.

解决方法 你正在循环中改变dp
while () {    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数组的指针,增加动态分配所遇到的程序开发问题。

如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/langs/1234771.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-06-06
下一篇 2022-06-06

发表评论

登录后才能评论

评论列表(0条)

保存