0

我在代码中出现分段错误时遇到了麻烦。我正在尝试制作一个将十进制数转换为十六进制数的函数。另外,如果我要使用:15&15,数字是 1111 还是 15?

这是我的代码:

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

char *to_hex(int n);

main(){
    int dec;
    printf("-> ");
    scanf("%d",dec);
    printf(to_hex(dec));
}

char *to_hex(int n){
    char *array = malloc(sizeof(int)*2+8);/*makes array*/
    int i;
    int index=0;/*used for storing into array*/
    for(i=28;i>-1;i=i-4){/*mask and compare 8 times*/
        int shift=n>>i;/*right shift*/
        int mask=shift&15;/*masks*/
        if (mask<10){
            *(array+index)=(char)mask;
            index++;
        }
        else{
            switch(mask){
            case 10:
                *(array+index)='a';
                index++;
                break;
            case 11:
                *(array+index)='b';
                index++;
                break;
            case 12:
                *(array+index)='c';
                index++;
                break;
            case 13:
                *(array+index)='d';
                index++;
                break;
            case 14:
                *(array+index)='e';
                index++;
                break;
            case 15:
                *(array+index)='f';
                index++;
                break;
            }
        }
    }
    *(array+index)='\0';
    return array;
}

我认为 : int mask : 等于 15 而不是 1111 我正确吗?谢谢

4

1 回答 1

0

您可以通过更改scanf("%d",dec);为来避免段错误scanf("%d",&dec);,如果您想要可打印的结果,请更改*(array+index)=(char)mask;*(array+index)=(char)mask+'0';(或者,更好,array[index] = mask + '0';

printf(to_hex(dec));也有点不确定。改为使用printf("%s",to_hex(dec));;它更安全。

于 2013-10-28T16:45:20.613 回答