我只是为自己的itoa编写代码(仅用于正数)并且我尝试使其尽可能高效,我从函数内部和main中显示值,并且它可以工作,但是当我删除printf时从函数内部开始,代码不再起作用了,有人知道为什么吗?
这就是它的工作地点
这是它不起作用的地方
感谢您的时间! 祝你有愉快的一天
代码:
#include<stdio.h>
#define uint8_t unsigned char
#define uint16_t unsigned int
/*Prototipos de funciones*/
uint8_t *UART0_itoa(uint16_t number, uint8_t base);
/*Función principal*/
void main(){
uint8_t *cadena;
cadena = UART0_itoa(255, 16);
printf("The String in main: %s\n",cadena);
}
/*Declaración de funciones*/
uint8_t *UART0_itoa(uint16_t number, uint8_t base){
uint8_t *aux;
*aux = '\0';
while(number){
*--aux = (number%base>9)?(number%base)+'7':(number%base)+'0';
number/=base;
}
//printf("The String in the function: %s\n",aux);
return aux;
}
答案 0 :(得分:0)
问题是你没有为aux
分配任何内存 - 它是一个未初始化的指针。您写入的任何内容,包括*aux = '\0'
的初始分配,都是未定义的行为。
您需要更改代码以获取输出缓冲区,或使用malloc
动态分配它。尝试向后写入数字是一个很好的 - 你可以通过传递缓冲区的结尾使其工作,如下所示:
uint8_t *UART0_itoa(uint16_t number, uint8_t base, char *aux){
while(number){
*--aux = (number%base>9)?(number%base)+'7':(number%base)+'0';
number/=base;
}
return aux;
}
并致电
char buf[16];
cadena = UART0_itoa(255, 16, &buf[15]);