我正在尝试创建一个嵌入式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:最大值是:
任何人都可以解释这种奇怪的行为。
答案 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'));