H20*_*019 3 c hex cygwin decimal
我有不同的十六进制数据即将到来并存储到一个整数类型寄存器中。
当我使用 fprint 时,我可以看到以下内容:
0x3076
0x307c
.
.
.
Run Code Online (Sandbox Code Playgroud)
但是,我想显示上述十六进制数据的十进制版本,如下所示。
12406
12412
.
.
.
Run Code Online (Sandbox Code Playgroud)
理论上,假设第一个值您执行以下操作将其转换为十进制。
(6* 16^0)+(7 * 16^1)+(0*16^2)+(3*16^3)=6 + 112+ 0 + 12288 = 12406
Run Code Online (Sandbox Code Playgroud)
因此,如果我有“0x3076”的基于字符的版本,而且,如果我能够获得每个单个字符 6 - 7 - 0 - 3,我可以计算十进制数量!
所以,我决定将“3076”除以 1000。我原本希望得到 3,但我得到了两个字符!但是,如果我能够为“307c”的其余部分获得 3,我将无法获得“C”。如果它是十进制的,这可能不是十六进制的!
另外,我尝试了“ strtol”命令。当我使用 Cygwin 编译我的代码时,我不确定错误在哪里!我做错了什么?
所以,我只需要找到一种方法来从 HEX 数据中获取每个单个字符!
请问有什么想法吗?
聚苯乙烯
这是我的代码,以帮助您给我一个想法。
int get_readings(int source, int phase, int max_tries)
{
uint8_t buf[MAX_IEC1107_MSG_BODY];
uint8_t inbuf[MAX_IEC1107_MSG_BODY];
int inlen;
uint8_t *s;
int32_t value;
int status;
double voltage;
double current;
double active_power;
double reactive_power;
double apparent_power;
double power_factor;
double frequency;
s = buf;
*s++ = HOST_CMD_GET_READINGS_PHASE_1 + phase;
*s++ = 0x00;
if (max_tries != 1)
meter_set_max_tries(&emeter[source].meter_msg, max_tries);
if (meter_exchange(&emeter[source].meter_msg, buf, 2, inbuf, &inlen)
&&
inbuf[1] != 0xFF)
{
emeter[source].no_response = FALSE;
s = inbuf;
/* Get current readings */
value = (s[3] << 8) | s[2];
fprint(stderr, "value:" %p\n, value); // this give me HEX code
Run Code Online (Sandbox Code Playgroud)
. . .
读入表示十六进制数字的字符串时,使用strtol()将其转换为 long。然后,如果你要打印十进制数,使用printf()与%d格式说明。
char num[]="0x3076";
long n = strtol(num, NULL, 16);
printf("n=%ld\n", n); // prints 12406
Run Code Online (Sandbox Code Playgroud)
一旦你读入字符串作为 longs 使用strtol并在 longs 上操作,数学应该自己解决。
只有通过以下行我才能解决问题!
fprintf(stderr, "Voltage: %.2f\n", value/100.00);
Run Code Online (Sandbox Code Playgroud)
值显示为十六进制,因为我以前使用 %p! 然后我就改成x了!由于我需要 124.06 而不是 12406,换句话说,需要 2 位小数,所以我添加了 .2f!
谢谢你们!