尾递归函数中的分段错误?

Segmentation fault error in tail recursive function?

我正在用 C 编写一个函数,将数字转换为不同的基数,例如八进制、二进制、十六进制等。我们需要递归地编写它,并且该函数必须 return 一个 char *。但是,我在这个代码片段中遇到了分段错误。我也不确定转换是否正常工作,因为我无法克服这个错误。我是 C 的新手,所以如果有什么明显遗漏的地方,我深表歉意。

#include <stdio.h>

char *convertToBaseOut(short int num, int base);

int main()
{
    printf("%s", convertToBaseOut(256, 8));
    return 0;
}

char *convertToBaseOut(short int num, int base) {
    if (num == 0) {
        return '0';
    }
    return convertToBaseOut(num/base, base) + (num % base);
}

分段错误

...程序已完成,退出代码为 139

在 C 中,您不能使用 + 连接字符串。

这里有简单的递归函数:

size_t tostring(char *str, unsigned num, unsigned base)
{
    static const char digits[] = "0123456789ABCDEF";

    size_t pos;
    if(!num)
    {
        return 0;
    }
    else
    {
        pos = tostring(str, num / base, base);
        str[pos++] = digits[num % base];
        str[pos] = 0;
    }
    return pos;
}

int main()
{

    char str[20];
    printf("%u\n" , tostring(str,0xabcd, 2));
    printf("%s\n", str);

    return 0;
}

它也重新计算字符串的长度。