欢迎访问 生活随笔!

生活随笔

当前位置: 首页 >

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

发布时间:2023/12/15 47 豆豆
生活随笔 收集整理的这篇文章主要介绍了 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虚拟机的源码证实。

 

 

总结:

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

总结

以上是生活随笔为你收集整理的Linux内核中__u16、__u32、__u64和size_t的理解的全部内容,希望文章能够帮你解决所遇到的问题。

如果觉得生活随笔网站内容还不错,欢迎将生活随笔推荐给好友。