如何将十六进制值转换为 WORD、DWORD 或 QWORD 并将结果存储在双变量中?

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)

http://ideone.com/mqjldk

但是为什么 DWORD 和 QWORD 转换也没有返回-3805

我的意思是:0xFFFFF123存储在 DWORD 中将包含-3805十进制值,而不是2147483647

预期输出:

WORD=-3805
DWORD=-3805
QWORD=-3805
Run Code Online (Sandbox Code Playgroud)

你有按位替代吗?

124*_*123 5

如果 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)