我只是为我自己的 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]);
本文收集自互联网,转载请注明来源。
如有侵权,请联系[email protected] 删除。
我来说两句