Linux内核中__u16、__u32、__u64和size_t的理解

写在前面:文章选用版本信息:Linux内核2.6.0版本、x86架构。

__u系列

为什么会出现__u系列的宏定义呢?

原因很简单,内核需要帮你适配不同cpu架构、cpu位数。

因为在32位系统中,int和long都是32位4字节的大小。而在64位系统中,int是32位4字节、long是64位8字节。在32位机中表示64位需要写成long long,这样打包运行在不同位数的机器上,就会出现未知的问题。所以内核就帮开发者适配不同机器位数的大小,如下图所示,各个平台不同位数的cpu内核都已完成适配。在开发中,直接使用内核定义的__u系列的宏定义即可。

Linux内核中__u16、__u32、__u64和size_t的理解_第1张图片

看到__u64在32位和64机的实现细节。

// i386  32位机
typedef unsigned long long __u64;	
// ia64  64位机
typedef unsigned long __u64;

size_t

再看到size_t的宏定义,也跟__u系列一样,内核也是帮开发者适配了不同平台不同架位的CPU。所以开发者只需要使用内核宏定义的size_t即可。

Linux内核中__u16、__u32、__u64和size_t的理解_第2张图片

看到32位和64位的实现区别: 

// i386 32位机
typedef unsigned int	__kernel_size_t;
// ia64   64位机
typedef unsigned long	__kernel_size_t;

内核中为什么存在u和__u二种宏定义系列呢?

Linux内核中__u16、__u32、__u64和size_t的理解_第3张图片

内核中注释写的非常明白,__u系列是可以暴露出去使用的,而u系列是只能在内核中使用的。

并且u系列的底层就是__u系列。

所以为了证实__u系列是暴露出去的,笔者特意打开了hotspot虚拟机的源码证实。

Linux内核中__u16、__u32、__u64和size_t的理解_第4张图片

Linux内核中__u16、__u32、__u64和size_t的理解_第5张图片 

Linux内核中__u16、__u32、__u64和size_t的理解_第6张图片

 

总结:

最后,如果本帖对您有一定的帮助,希望能点赞+关注+收藏!您的支持是给我最大的动力,后续会一直更新各种框架的使用和框架的源码解读~!

你可能感兴趣的:(深入理解Linux2.6内核,源码解读,Linux内核,Linux2.6内核,C语言,cpu架构)