ASCII to int to ASCII (ATMEGA 2560)



我正在尝试制作一个嵌入式的C项目,我将输入7个字符并与它们进行一些计算 - 现在我遇到了我的转换来工作的问题 - 我正在使用一个atmega 2560,我在uart上输出字符。

这是代码:

volatile char daata[8] = "123:456";
volatile char recdata[8];
volatile char data = 0;
volatile char byte;
volatile int minimum;
volatile int maximum;
volatile char mx;
volatile char mi;

我的功能使用:

void putsUSART0(char *ptr)
{
    while(*ptr)
    {
        putchUSART0(*ptr);
        ptr++;
    }
}

void putchUSART0(char tx)
{
    while(!(UCSR0A & (1 << UDRE0)));   // wait for empty transmit buffer
    UDR0 = tx;
}

代码在哪里工作的是:

minimum = (100 * (daata[0] - 0x30) + 10 * (daata[1] - 0x30) + daata[2] - 0x30);
maximum = daata[6] - 0x30 + 10 * (daata[5] - 0x30) + 100 * (daata[4]);
mi = minimum + 0x30;
putsUSART0("mimimum is:");
//putchUSART0(minimum );
putsUSART0(mi);
putsUSART0("maximum is:");
putchUSART0(maximum);
_delay_ms(5000);
status = requestsample;

问题是我的输出是

Mimimum是:最大值IS:ˆ

任何人都可以解释奇怪的行为。

char buf[15];
...
mi = minimum + 0x30;
sprintf(buf, "%d", mi);
putsUSART0("mimimum is:");
//putchUSART0(minimum );
putsUSART0(buf);

最大值也相似

您是在发送ASCII字符的值(并通过添加0x30来转换为字符,这不是正确的方式,您需要转换所有数字),并且可能在另一端不转换而无需打印它。


lundin的评论

sprintf()可能不是一个选项,因为这是一个嵌入式项目, 该功能通常太慢而耗时太慢。

您还可以编写自己的功能,该功能可以将数字转换为字符串:

const char *numToStr(int n) {
  /* Non-reentrant, returned buffer will be invalidated on subsequent call */
#define BUF_SIZE 15
  static char buf[BUF_SIZE] = {0};
  int pos = BUF_SIZE - 1;
  int neg = 0;
  if(n < 0) {
    neg = 1;
    n *= -1;
  }
  do {
    buf[--pos] = (n % 10) + '0';
    n /= 10;
  } while(n);
  if(neg) buf[--pos] = '-';
  return &buf[pos];
}

并用它将数字转换为字符串。


chux的善意

numtoStr(int_min)建议if(n < 0) { neg = 1; } else { n = -n; } do { buf[--pos] = '0' - (n % 10); n /= 10; } while(n);

失败

可以写入INT_MIN的版本可以写为:

const char *numToStr(int n) {
  /* Non-reentrant, returned buffer will be invalidated on subsequent call */
#define BUF_SIZE 15
  static char buf[BUF_SIZE] = {0};
  int pos = BUF_SIZE - 1;
  int neg = 0;
  if(n < 0) {
    neg = 1;
  } else {
    n = -n;
  }
  do {
    buf[--pos] = '0' - (n % 10);
    n /= 10;
  } while(n);
  if(neg) buf[--pos] = '-';
  return &buf[pos];
}

daata[4]应该为 daata[4] - 0x30。这会导致您按预期获得100*52而不是100*4。

避免这样的简单错误的方法是一些编码纪律:不要将所有内容都放在同一条线上,保持一致并避免"魔术数字"。

minimum =   (100 * (data[0] - '0') 
          + ( 10 * (data[1] - '0') 
          + (  1 * (data[2] - '0');
maximum =   (100 * (data[4] - '0'))
          + ( 10 * (data[5] - '0'))
          + (  1 * (data[6] - '0'));

相关内容

  • 没有找到相关文章

最新更新