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系列的宏定义即可。

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

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

size_t

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

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

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

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

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

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

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

 

 

总结:

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

  • 6
    点赞
  • 13
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 2
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

程序员李哈

创作不易,希望能给与支持

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值