c - 方法返回的指针未正确分配给 C 中定义的另一个指针

标签 c if-statement pointers scope declaration

我是 C 编程初学者。在处理简单的作业时,我的代码因段错误而崩溃。当我用 gdb 调试时,我发现从“manchester”方法返回的指针与 main 中“编码”的分配指针不同。

我的代码如下

#include <stdio.h>
#include <stdlib.h>

char* manchester(char* bitstring);
char* differential_manchester(char* bitstring);

int main(){
    int method;
    scanf("%i\n", &method);   //scan the method to encode
    char* bitstring = (char *) malloc(100*sizeof(char)); // assumed max length = 100
    scanf("%s", bitstring);

    char* encoded;
    if(method == 0){
        char* encoded = manchester(bitstring); // where the confusion occur
    }
    else if (method == 1){
        char* encoded = differential_manchester(bitstring);
    }
    printf("%s", encoded);
    free(encoded);
    free(bitstring);

    return 0;
}

char* manchester(char* bitstring){
    char* encoded_st = (char*) malloc(200*sizeof(char));
    int i = 0, j = 0;
    while (bitstring[i] != '\0' ){
        if (bitstring[i++] == '0'){
            encoded_st[j++] = '1';
            encoded_st[j++] = '0';
        }
        else{
            encoded_st[j++] = '0';
            encoded_st[j++] = '1';
        }
    }
    encoded_st[j++] = 0; //append null character at end
    return encoded_st;
}

char* differential_manchester(char* bitstring){
    //TODO: yet to implement
    return NULL;
} 

gdb调试

(gdb) b encode.c:14
Breakpoint 1 at 0x1222: file encode.c, line 14.
(gdb) run
Starting program: /home/ishad/Desktop/computer communication/a.out 
0
1010

Breakpoint 1, main () at encode.c:14
14      if(method == 0){
(gdb) n
15          char* encoded = manchester(bitstring);
(gdb) s
manchester (bitstring=0x7ffff7e5a2d4 <__GI___libc_malloc+116> "I\211\300H\205\300\017\204\300") at encode.c:27
27  char* manchester(char* bitstring){
(gdb) n
28      char* encoded_st = (char*) malloc(200*sizeof(char));
(gdb) n
29      int i = 0, j = 0;
(gdb) n
30      while (bitstring[i] != '\0' ){
(gdb) n
31          if (bitstring[i++] == '0'){
(gdb) n
36              encoded_st[j++] = '0';

...

(gdb) n
30      while (bitstring[i] != '\0' ){
(gdb) n
40      encoded_st[j++] = 0; //append null character at end
(gdb) n
41      return encoded_st;
(gdb) p encoded_st
$1 = 0x555555559720 "01100110"
(gdb) n
42  }
(gdb) n
main () at encode.c:20
20      printf("%s", encoded);
(gdb) p encoded
$2 = 0x7fffffffdec0 "\001"

我的问题是为什么encoded_st指针与encoded指针不同。 我试图用几个关键词来寻找原因。但我没有找到类似的问题。 :(

最佳答案

您在 if 语句的范围内重新声明了同名encoded变量

char* encoded;
if(method == 0){
    char* encoded = manchester(bitstring); // where the confusion occur
}
else if (method == 1){
    char* encoded = differential_manchester(bitstring);
}

因此,在相对于 if 语句的外部作用域中声明的变量 encoded 保持未初始化状态。

删除if语句中的声明

char* encoded;
if(method == 0){
    encoded = manchester(bitstring); // where the confusion occur
}
else if (method == 1){
    encoded = differential_manchester(bitstring);
}

关于c - 方法返回的指针未正确分配给 C 中定义的另一个指针,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/69046365/

相关文章:

javascript - 如何仅当innerHTML超过99时才用Javascript弹出警报?

c - GHC 运行时如何处理文件 I/O?

c - 首先添加什么 '\n' 或 '\0'

java - if 语句和输入来计算温度

python - Python中根据多个条件返回列的方法

java - 使用 long 将指针从 JNI 传递到 Java

c - 将指针分配给列表中的下一个节点

c - 如何在 C 中创建一个函数,允许我根据分隔符将字符串拆分为数组?

c - 赋值使指针来自整数而不进行强制转换 (c)

c - C 中 2 种数据类型/MAP 的数组