ASCII到int到ASCII(ATMEGA 2560)

时间:2015-05-05 12:57:27

标签: c++ c embedded uart

我正在尝试创建一个嵌入式c项目,我将输入7个字符并对它们进行一些计算 - 现在我遇到问题让我的转换工作 - 我正在使用ATMEGA 2560,我输出字符在uart上。

以下是代码:

volatile char daata[8] = "123:456\0";
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:最大值是:

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

2 个答案:

答案 0 :(得分:4)

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];
}

答案 1 :(得分:0)

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

避免像这样的简单错误的方法是一些编码规则:不要把所有东西放在同一条线上,保持一致并避免&#34;魔术数字&#34;。

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'));