LOWORD, HIWORD, LOBYTE, HIBYTE的解释

文章目录

实验

int 类型大小正常为4Byte

以小端序来看 0x12345678在内存中的存储为

csharp 复制代码
0x78 0x56 0x34 0x12

0x78在低地址,0x12在高地址

程序输出

csharp 复制代码
#include <stdio.h>
#include <string.h>
#include<windows.h>

int main()
{
    int a = 0x12345678;
    printf("LOWORD %x\n",LOWORD(a));
    printf("HIWORD %x\n",HIWORD(a));
    printf("LOBYTE %x\n",LOBYTE(a));
    printf("HIBYTE %x\n",HIBYTE(a));
}
csharp 复制代码
LOWORD 5678
HIWORD 1234
LOBYTE 78
HIBYTE 56

结论

可以看到以WORD结尾的是取出两个字节

BYTE结尾取出一个字节

LOWORD 是取出内存中低地址的前两个字节

HIWORD 是取出内存中高地址的后两个字节

LOBYTE 取出了内存中最低的一个字节0x78

HIBYTE 取出了第二个字节0x56

从这里来看,他们是以两个字节为操作对象,哪怕给出的数据是int类型的数据

按照我的猜测以WORD结尾的就是以4个字节为操作对象了

以下是测试

csharp 复制代码
#include <stdio.h>
#include <string.h>
#include <windows.h>

int main()
{
    unsigned long long a = 0x123456789abcdef0;

    printf("long long -> %x\n", sizeof(unsigned long long));
    printf("LOWORD %x\n", LOWORD(a));
    printf("HIWORD %x\n", HIWORD(a));
    printf("LOBYTE %x\n", LOBYTE(a));
    printf("HIBYTE %x\n", HIBYTE(a));
}

此时a在内存中的表示为

csharp 复制代码
0xf0 0xde 0xbc 0x9a 0x78 0x56 0x34 0x12

输出结果为

csharp 复制代码
long long -> 8
LOWORD def0
HIWORD 9abc
LOBYTE f0
HIBYTE de

看来和我们的猜想一致

相关推荐
脱氧核糖核酸__17 分钟前
LeetCode 热题100——42.接雨水(题目+题解+答案)
数据结构·c++·算法·leetcode
王老师青少年编程1 小时前
csp信奥赛C++高频考点专项训练之贪心算法 --【线性扫描贪心】:数列分段 Section I
c++·算法·编程·贪心·csp·信奥赛·线性扫描贪心
王老师青少年编程1 小时前
csp信奥赛C++高频考点专项训练之贪心算法 --【线性扫描贪心】:分糖果
c++·算法·贪心算法·csp·信奥赛·线性扫描贪心·分糖果
leaves falling2 小时前
C++模板进阶
开发语言·c++
无敌昊哥战神2 小时前
【保姆级题解】力扣17. 电话号码的字母组合 (回溯算法经典入门) | Python/C/C++多语言详解
c语言·c++·python·算法·leetcode
脱氧核糖核酸__2 小时前
LeetCode热题100——238.除了自身以外数组的乘积(题目+题解+答案)
数据结构·c++·算法·leetcode
ouliten2 小时前
C++笔记:std::invoke
c++·笔记
j_xxx404_3 小时前
C++算法:哈希表(简介|两数之和|判断是否互为字符重排)
数据结构·c++·算法·leetcode·蓝桥杯·力扣·散列表
脱氧核糖核酸__4 小时前
LeetCode热题100——189.轮转数组(题解+答案+要点)
数据结构·c++·算法·leetcode
coding者在努力4 小时前
被n整除的n位数
c++·算法