天空随你便
2021-06-18 11:49
采纳率: 100%
浏览 52

关于LINUX编程 char *value = argv[1]; 导致段错误 (核心已转储)问题

直接上代码:

#include <stdio.h>
#include <string.h>

int main (int argc,char** argv)
{
#if 1   //PLAN a

        //method A
        char* key,value;
        printf("a:K:%s,V:%s\r\n",argv[2],argv[3]);
        key = argv[2];
        value = argv[3];

        //method B
        char *key,*value;
        printf("a:K:%s,V:%s\r\n",argv[2],argv[3]);
        strcpy(key,argv[2]);
        strcpy(value,argv[3]);

        printf("b:K:%s,V:%s\r\n",key,value);

#else   //PLAN b
        char key[16],value[16];
        printf("a:K:%s,V:%s\r\n",argv[2],argv[3]);
        strcpy(key,argv[2]);
        strcpy(value,argv[3]);
        printf("b:K:%s,V:%s\r\n",key,value);
#endif
        return 0;
}

编译环境:UBUNTU下自带的GCC

执行:

$ ./test 1 sky 123

输出:

a:K:sky,V:123
段错误 (核心已转储)

 

PLAN b输出无误。

PLAN  a下面的 method A、B都不行,反馈都是段错误 (核心已转储)

请问大佬们知道这个错误的原因在哪儿吗?
 

  • 写回答
  • 好问题 提建议
  • 追加酬金
  • 关注问题
  • 邀请回答

3条回答 默认 最新

  • 爱晚乏客游 2021-06-18 13:05
    最佳回答

    char* key,value;你的value是char而不是char *

    评论
    解决 1 无用
    打赏 举报
查看更多回答(2条)

相关推荐 更多相似问题