我只是为我自己的 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;
}
最佳答案
问题是您没有为 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]);
关于c - 使用 printf 和不使用 printf 实现 itoa 函数时出现的问题,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/44477744/