LARGE_INTEGER 大整数

一、LARGE_INTEGER(large大 integer整数)

这里解释前面碰到的LARGE_INTEGER结构。与可能的误解不同,64位数据并非要在64位操作系统下才能使用。在VC中,64位数据的类型为__int64。定义写法如下:

__int64 file_offset;	//文件偏移
上面之所以定义的变量名为file_offset,是因为文件中的偏移量是一种常见的要使用64位数据的情况。同时,文件的大小也是如此(回忆上一小节中定义的文件大小)。32位数据无符号整型只能表示到4GB。而众所周知,现在超过4GB的文件绝对不罕见了。但是实际上__int64这个类型在驱动开发中很少被使用。基本上被使用到的是一个共用体:LARGE_INTEGER。这个共用体定义如下:
 typedef __int64 LONGLONG;  
    typedef union _LARGE_INTEGER {
        struct {
            ULONG LowPart;
            LONG HighPart;
        };
        struct {
            ULONG LowPart;
            LONG HighPart;
        } u;
        LONGLONG QuadPart;
    } LARGE_INTEGER;
这个共用体的方便之处在于,既可以很方便的得到高32位,低32位,也可以方便的得到整个64位。进行运算和比较的时候,使用QuadPart即可。

L
ARGE_INTEGER a,b;
    a.QuadPart = 100;
    a.QuadPart *= 100;
    b.QuadPart = a.QuadPart;
    
    if(b.QuadPart > 1000)
    {
        KdPrint(“b.QuadPart < 1000, LowPart = %x HighPart = %x”, b.LowPart,b.HighPart);
    }
上面这段代码演示了这种结构的一般用法。在实际编程中,会碰到大量的参数是LARGE_INTEGER类型的。

驱动开发中,我们除了可以使用LONGLONG这个表示64位结构的数据外。还可以使用一个叫做LARGE_INTEGER的数据结构来表示64位数据。它的定义如下

[cpp] view plain copy

typedef union _LARGE_INTEGER {  
    struct {  
        ULONG LowPart;		//低32位整数
        LONG HighPart;  	//高32位整数
    } DUMMYSTRUCTNAME;  
    struct {  
        ULONG LowPart;  	
        LONG HighPart;  
    } u;  
#endif //MIDL_PASS  
    LONGLONG QuadPart;  
} LARGE_INTEGER;  

LARGE_INTEGER是一个联合体。设计的非常巧妙。联合体中的3个元素可以被认为是LARGE_INTEGER的3个定义
(1)DUMMYSTRUCTNAME由2部分组成。一个是低位的32位整数LowPart。另一个就是高位的整数咯。在小端的情况下。低32位数字在前。高32位在后。

如果将这个64位整数赋值100.可以这么写

[cpp] view plain copy

LARGE_INTEGER value;  
value.LowPart = 100;  
value.HighPart = 0;  

(2)u由2部分组成。一个是低位的32位整数LowPart。另一个就是高位的整数咯。在大端的情况下。高32位数字在前。低32位在后。
如果将这个64位整数赋值100.可以这么写

[cpp] view plain copy

LARGE_INTEGER value;  
value.u.LowPart = 100;  
value.u.HighPart = 0;  

(3)当LARGE_INTEGER 等价于LONGLONG的时候。如果将这个64位整数赋值100.可以这么写

[cpp] view plain copy

LARGE_INTEGER value;  
value.QuadPart = 100;  

union联合

选择:
成员是
一个int i还是
一个char c
sizeof(union……)=sizeof(每个成员)的最大值

union AnElt{
int i;
char c;
}elt1,elt2;

elt1.i=4;
elt2.c=‘a’;
elt2.i=0xDEADBEFF

对于union,它的任何成员变量所占据的空间,只有一份,所以叫做联合,大家联合起来使用同一个空间
通过i填一个值,再通过c填一个值进去的话,就把前面的值覆盖掉了,但i还是有值的

union的用处

typedef union{
    int i;
    char ch[sizeof(int)];
}CHI;

int main(int argc,char const *argv[])
{
CHI chi;
int i;
chi.i=1234; //0x04D2
for( i=0; i < sizeof(int); i++ )
{
printf("%02hhX",chi.ch[i]);

    //FFD2040000  x86小端机器,低位在前,一个数放在内存里的时候,它要把低的东西放在前面
    //可以通过这种方式得到一个数字内部的各个字节
    //比如,当我们要做文件操作的时候,当我们要把一个整数以二进制的形式写到一个文件里头去的时候
    //这就是用来做读写的一个中间的没接
}
printf("\n");
return 0;

}

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值