har*_*on4 3 c hex casting dword
我正在尝试通过这种方式将带符号的十六进制数转换为 WORD、DWORD 和 QWORD:
#include <stdio.h>
#include <stdlib.h>
#include <inttypes.h>
int main(void) {
printf("WORD=%d\n", (int16_t) strtol("F123", NULL, 16));
printf("DWORD=%d\n", (int32_t) strtol("FFFFF123", NULL, 16));
printf("QWORD=%lld\n", (int64_t) strtol("FFFFFFFFFFFFF123", NULL, 16));
return 0;
}
Run Code Online (Sandbox Code Playgroud)
但它返回以下内容:
WORD=-3805
DWORD=2147483647
QWORD=2147483647
Run Code Online (Sandbox Code Playgroud)
但是为什么 DWORD 和 QWORD 转换也没有返回-3805?
我的意思是:0xFFFFF123存储在 DWORD 中将包含-3805十进制值,而不是2147483647
预期输出:
WORD=-3805
DWORD=-3805
QWORD=-3805
Run Code Online (Sandbox Code Playgroud)
你有按位替代吗?
如果 long int 有 32 位,则 0xFFFFFF123 超出 long int 的范围,因此 strtol() 返回 LONG_MAX(在我们的例子中为 0x7FFFFFFF = 2147483647)。
使用 strtoull() 将字符串转换为至少 64 位的无符号整数,并在继续之前始终检查错误。
要打印具有指定位大小的整数,请使用以下内容:
printf("foo=%"PRIu32"\n",(uint32_t) foo);
Run Code Online (Sandbox Code Playgroud)
更好的方法:
#include <stdio.h>
#include <stdlib.h>
#define __STDC_FORMAT_MACROS //we need that for PRI[u]8/16/32 format strings
#include <inttypes.h>
#include <errno.h>
void error_exit(void)
{
perror("ups");
exit(EXIT_FAILURE);
}
int main(void)
{
unsigned long long temp;
errno=0;
temp = strtoull("FFFFF123", NULL, 16);
if(errno)
{
error_exit();
}
printf("DWORD=%"PRId32"\n", (int32_t) temp );
errno=0;
temp = strtoull("FFFFFFFFFFFFF123", NULL, 16);
if(errno)
{
error_exit();
}
printf("QWORD=%"PRId64"\n", (int64_t) temp );
return EXIT_SUCCESS;
}
Run Code Online (Sandbox Code Playgroud)
| 归档时间: |
|
| 查看次数: |
2696 次 |
| 最近记录: |