LARGE_INTEGER解析

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

[cpp]  view plain  copy
  1. typedef union _LARGE_INTEGER {  
  2.     struct {  
  3.         ULONG LowPart;  
  4.         LONG HighPart;  
  5.     } DUMMYSTRUCTNAME;  
  6.     struct {  
  7.         ULONG LowPart;  
  8.         LONG HighPart;  
  9.     } u;  
  10. #endif //MIDL_PASS  
  11.     LONGLONG QuadPart;  
  12. } LARGE_INTEGER;  

    

    LARGE_INTEGER是一个联合体。设计的非常巧妙。联合体中的3个元素可以被认为是LARGE_INTEGER的3个定义

(1)DUMMYSTRUCTNAME由2部分组成。一个是低位的32位整数LowPart。另一个就是高位的整数咯。在小端的情况下。低32位数字在前。高32位在后。

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

[cpp]  view plain  copy
  1. LARGE_INTEGER value;  
  2. value.LowPart = 100;  
  3. value.HighPart = 0;  
(2)u由2部分组成。一个是低位的32位整数LowPart。另一个就是高位的整数咯。在大端的情况下。高32位数字在前。低32位在后。

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

[cpp]  view plain  copy
  1. LARGE_INTEGER value;  
  2. value.u.LowPart = 100;  
  3. value.u.HighPart = 0;  

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

[cpp]  view plain  copy
  1. LARGE_INTEGER value;  
  2. value.QuadPart = 100;  

   

     文章转载自:https://blog.csdn.net/nowayings/article/details/44812201


猜你喜欢

转载自blog.csdn.net/li_wen01/article/details/80163946