ImageVerifierCode 换一换
格式:DOCX , 页数:16 ,大小:176.03KB ,
资源ID:10242209      下载积分:12 金币
快捷下载
登录下载
邮箱/手机:
温馨提示:
快捷下载时,用户名和密码都是您填写的邮箱或者手机号,方便查询和重复下载(系统自动生成)。 如填写123,账号就是123,密码也是123。
特别说明:
请自助下载,系统不会自动发送文件的哦; 如果您已付费,想二次下载,请登录后访问:我的下载记录
支付方式: 支付宝    微信支付   
验证码:   换一换

加入VIP,免费下载
 

温馨提示:由于个人手机设置不同,如果发现不能下载,请复制以下地址【https://www.bdocx.com/down/10242209.html】到电脑端继续下载(重复下载不扣费)。

已注册用户请登录:
账号:
密码:
验证码:   换一换
  忘记密码?
三方登录: 微信登录   QQ登录  

下载须知

1: 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。
2: 试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓。
3: 文件的所有权益归上传用户所有。
4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
5. 本站仅提供交流平台,并不能对任何下载内容负责。
6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

版权提示 | 免责声明

本文(linux常用头文件详解.docx)为本站会员(b****7)主动上传,冰豆网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知冰豆网(发送邮件至service@bdocx.com或直接QQ联系客服),我们立即给予删除!

linux常用头文件详解.docx

1、linux常用头文件详解linux常用头文件详解POSIX标准定义的头文件 目录项 文件控制 文件名匹配类型 路径名模式匹配类型 组文件 网络数据库操作 口令文件 正则表达式 TAR归档值 终端I/O 符号常量,文件是Linux的系统调用,好比Windows中的windows.h 文件时间 字符扩展类型- INTERNET定义 套接字本地接口 INTERNET地址族 传输控制协议定义- 内存管理声明 Select函数 套接字借口 文件状态 进程时间 基本系统数据类型(如pid_t,size_t等) UNIX域套接字定义 系统名 进程控制-POSIX定义的XSI扩展头文件 cpio归档值 动态链

2、接 消息显示结构 文件树漫游 代码集转换使用程序 语言信息常量 模式匹配函数定义 货币类型 数据库操作 消息类别 轮询函数 搜索表 字符串操作 系统出错日志记录 用户上下文 用户限制 用户帐户数据库 - IPC(命名管道) 消息队列资源操作 信号量 共享存储 文件系统信息 时间类型 附加的日期和时间定义 矢量I/O操作-POSIX定义的可选头文件 异步I/O 消息队列 线程 执行调度 信号量 实时spawn接口 XSI STREAMS接口 事件跟踪 C/C+头文件一览Cinclude /设定插入点include /字符处理include /定义错误码include /浮点数处理include

3、/对应各种运算符的宏include /定义各种数据类型最值的常量include /定义本地化C函数include /定义数学函数include /异常处理支持include /信号机制支持include /不定参数列表支持include /常用常量include /定义输入输出函数include /定义杂项函数及内存分配函数include /字符串处理include /定义关于时间的函数include /宽字符处理及输入输出include /宽字符分类传统C+include /改用include /改用include /改用include /该类不再支持,改用中的stringstream标准C

4、+include /STL 通用算法include /STL 位集容器include /字符处理include /定义错误码include /浮点数处理include /对应各种运算符的宏include /定义各种数据类型最值的常量include /定义本地化函数include /定义数学函数include /复数类include /信号机制支持include /异常处理支持include /不定参数列表支持include /常用常量include /定义输入输出函数include /定义杂项函数及内存分配函数include /字符串处理include /定义关于时间的函数include /宽

5、字符处理及输入输出include /宽字符分类include /STL 双端队列容器include /异常处理类include /文件输入输出include /STL 定义运算函数(代替运算符)include /定义各种数据类型最值常量include /STL 线性列表容器include /本地化特定信息include /STL 映射容器include /STL通过分配器进行的内存分配include /动态内存分配include /STL常用的数字操作include /参数化输入输出include /基本输入输出支持include /输入输出系统使用的前置声明include /数据流输入输出i

6、nclude /基本输入流include /STL迭代器include /基本输出流include /STL 队列容器include /STL 集合容器include /基于字符串的流include /STL 堆栈容器include /标准异常类include /底层输入输出支持include /字符串类include /运行期间类型信息include /STL 通用模板类include /对包含值的数组的操作include /STL 动态数组容器C99增加的部分include /复数处理include /浮点环境include /整数格式转换include /布尔环境include /整型环

7、境include /通用类型数学宏而对于本书所描述的内核源代码,其中涉及的头文件则可以看作是对内核及其函数库所提供服务的一个概要说明,是内核及其相关程序专用的头文件。在这些头文件中主要描述了内核所用到的所有数据结构、初始化数据、常数和宏定义,也包括少量的程序代码。除了几个专用的头文件以外(例如块设备头文件blk.h),Linux 0.12内核中所用到的头文件都放在内核代码树的include/目录中。因此编译Linux 0.12内核无需使用开发环境提供的位于/usr/include/目录下的任何头文件。当然,tools/build.c程序除外。因为这个程序虽然被包含在内核源代码树中,但它只是一个

8、用于组合创建内核映像文件的工具程序或应用程序,不会被链接到内核代码中。从0.95版开始,内核代码树中的头文件需要复制到/usr/include/linux目录下才能顺利地编译内核。即从该版内核开始头文件已经与开发环境使用的头文件合二为一。14.1 include/目录下的文件内核所用到的头文件都保存在include/目录下。该目录下的文件如表11-1所示。这里需要说明一点:为了方便使用和兼容性,Linus在编制内核程序头文件时所使用的命名方式与标准C库头文件的命名方式相似,许多头文件的名称甚至其中的一些内容都与标准C库的头文件基本相同,但这些内核头文件仍然是内核源代码或与内核有紧密联系的程序专

9、用的。在一个Linux系统中,它们与标准库的头文件并存。通常的做法是将这些头文件放置在标准库头文件目录中的子目录下,以让需要用到内核数据结构或常数的程序使用。另外,也由于版权问题,Linus试图重新编制一些头文件以取代具有版权限制的标准C库的头文件。因此这些内核源代码中的头文件与开发环境中的头文件有一些重叠的地方。在Linux系统中,列表14-1中的asm/、linux/和sys/三个子目录下的内核头文件通常需要复制到标准C库头文件所在的目录(/usr/include)中,而其他一些文件若与标准库的头文件没有冲突则可以直接放到标准库头文件目录下,或者改放到这里的三个子目录中。asm/目录下主要

10、用于存放与计算机体系结构密切相关的函数声明或数据结构的头文件。例如Intel CPU 端口IO汇编宏文件io.h、中断描述符设置汇编宏头文件system.h等。linux/目录下是Linux内核程序使用的一些头文件。其中包括调度程序使用的头文件sched.h、内存管理头文件mm.h和终端管理数据结构文件tty.h等。而sys/目录下存放着几个与内核资源相关头文件。不过从0.98版开始,内核目录树下sys/目录中的头文件被全部移到了linux/目录下。Linux 0.12版内核中共有32个头文件(*.h),其中asm/子目录中含有4个,linux/子目录中含有10个,sys/子目录中含有5个。从

11、下一节开始我们首先描述include/目录下的13个头文件,然后依次说明每个子目录中的文件。说明顺序按照文件名称排序进行。14.2 a.out.h文件14.2.1 功能描述在Linux 内核中,a.out.h文件用于定义被加载的可执行文件结构。主要用于加载程序fs/exec.c中。该文件不属于标准C库,它是内核专用的头文件。但由于与标准库的头文件名没有冲突,因此在Linux系统中一般可以放/usr/include/目录下,以供涉及相关内容的程序使用。该头文件中定义了目标文件的一种a.out(Assembly out)格式。Linux 0.12系统中使用的.o文件和可执行文件就采用了这种目标文件

12、格式。a.out.h文件包括三个数据结构定义和一些相关的宏定义,因此文件可被相应地分成三个部分:第1108行给出并描述了目标文件执行头结构和相关的宏定义。第109185行对符号表项结构的定义和说明。第186217行对重定位表项结构进行定义和说明。由于该文件内容比较多,因此对其中三个数据结构以及相关宏定义的详细说明放在程序列表后。从0.96版内核开始,Linux系统直接采用了GNU的同名头文件a.out.h。因此造成在Linux 0.9x下编译的程序不能在Linux 0.1x系统上运行。下面对两个a.out头文件的不同之处进行分析,并说明如何让0.9x下编译的一些不是用动态链接库的执行文件也能在

13、0.1x下运行。Linux 0.12使用的a.out.h文件与GNU同名文件的主要区别在于exec结构的第一个字段a_magic。GNU的该文件字段名称是a_info,并且把该字段又分成3个子域:标志域(Flags)、机器类型域(Machine Type)和魔数域(Magic Number)。同时为机器类型域定义了相应的宏N_MACHTYPE和N_FLAGS,如图14-1所示。在Linux 0.9x系统中,对于采用静态库连接的执行文件,图中各域注释中括号内的值是该字段的默认值。这种二进制执行文件开始处的4个字节是:0x0b, 0x01, 0x64, 0x00而这里的头文件仅定义了魔数域。因此,

14、在Linux 0.1x系统中一个a.out格式的二进制执行文件开始的4个字节是:0x0b, 0x01, 0x00, 0x00可以看出,采用GNU的a.out格式的执行文件与Linux 0.1x系统上编译出的执行文件的区别仅在机器类型域。因此我们可以把Linux 0.9x上的a.out格式执行文件的机器类型域(第3个字节)清零,让其运行在0.1x系统中。只要被移植的执行文件所调用的系统调用都已经在0.1x系统中实现即可。在开始重新组建Linux 0.1x根文件系统中的很多命令时,作者就采用了这种方法。在其他方面,GNU的a.out.h头文件与这里的a.out.h没有什么区别。14.2.3 a.o

15、ut执行文件格式Linux内核0.12版仅支持a.out(Assembly out)执行文件和目标文件的格式,虽然这种格式目前已经渐渐不用,而使用功能更为齐全的ELF(Executable and Link Format)格式,但是由于其简单性,作为入门的学习材料比较适用。下面全面介绍一下a.out格式。在头文件a.out.h中声明了三个数据结构以及一些宏。这些数据结构描述了系统上目标文件的结构。在Linux 0.12系统中,编译产生的目标模块文件(简称模块文件)和链接生成的二进制可执行文件均采用a.out格式。这里统称为目标文件。一个目标文件由7部分(7节)组成。它们依次为:(1)执行头部分

16、(exec header)。该部分中含有一些参数(exec结构),内核使用这些参数把执行文件加载到内存中并执行,而链接程序(ld)使用这些参数将一些模块文件组合成一个可执行文件。这是目标文件唯一必要的组成部分。(2)代码段部分(text segment)。含有程序执行时被加载到内存中的指令代码和相关数据。可以以只读形式被加载。(3)数据段部分(data segment)。这部分含有已经初始化过的数据,总是被加载到可读写的内存中。(4)代码重定位部分(text relocations)。这部分含有供链接程序使用的记录数据。在组合目标模块文件时用于定位代码段中的指针或地址。(5)数据重定位部分(d

17、ata relocations)。类似于代码重定位部分的作用,但是用于数据段中指针的重定位。(6)符号表部分(symbol table)。这部分同样含有供链接程序使用的记录数据,用于在二进制目标模块文件之间对命名的变量和函数(符号)进行交叉引用。(7)字符串表部分(string table)。该部分含有与符号名对应的字符串。每个目标文件均以一个执行数据结构(exec structure)开始。该数据结构的形式如下:各个字段的功能如下:1)a_magic该字段含有三个子字段,分别是标志字段、机器类型标识字段和魔数字段,参见图11-1。不过对于Linux 0.12系统其目标文件只使用了其中的魔数子

18、字段,并使用宏N_MAGIC()来访问,它唯一地确定了二进制执行文件与其他加载的文件之间的区别。该子字段中必须包含以下值之一:OMAGIC。表示代码和数据段紧随在执行头后面并且是连续存放的。内核将代码和数据段都加载到可读写内存中。编译器编译出的目标文件的魔数是OMAGIC(八进制0407)。NMAGIC。同OMAGIC一样,代码和数据段紧随在执行头后面并且是连续存放的。然而内核将代码加载到了只读内存中,并把数据段加载到代码段后下一页可读写内存边界开始。ZMAGIC。内核在必要时从二进制执行文件中加载独立的页面。执行头部、代码段和数据段都被链接程序处理成多个页面大小的块。内核加载的代码页面是只读

19、的,而数据段的页面是可写的。链接生成的可执行文件的魔数即是ZMAGIC(0413,即0x10b)。2)a_text该字段含有代码段的长度值,字节数。3)a_data该字段含有数据段的长度值,字节数。4)a_bss含有bss段的长度,内核用其设置在数据段后初始的break(brk)。内核在加载程序时,这段可写内存显现出处于数据段后面,并且初始时为全零。5)a_syms含有符号表部分的字节长度值。6)a_entry含有内核将执行文件加载到内存中以后,程序执行起始点的内存地址。7)a_trsize该字段含有代码重定位表的大小,是字节数。8)a_drsize该字段含有数据重定位表的大小,是字节数。 在

20、a.out.h头文件中定义了几个宏,这些宏使用exec结构来测试一致性或者定位执行文件中各个部分(节)的位置偏移值。这些宏有:N_BADMAG(exec)。如果a_magic字段不能被识别,则返回非零值。N_TXTOFF(exec)。代码段的起始位置字节偏移值。N_DATOFF(exec)。数据段的起始位置字节偏移值。N_DRELOFF(exec)。数据重定位表的起始位置字节偏移值。N_TRELOFF(exec)。代码重定位表的起始位置字节偏移值。N_SYMOFF(exec)。符号表的起始位置字节偏移值。N_STROFF(exec)。字符串表的起始位置字节偏移值。重定位记录具有标准的格式,它使

21、用重定位信息(relocation_info)结构来描述,如下所示:该结构中各字段的含义如下:1)r_address该字段含有需要链接程序处理(编辑)的指针的字节偏移值。代码重定位的偏移值是从代码段开始处计数的,数据重定位的偏移值是从数据段开始处计算的。链接程序会将已经存储在该偏移处的值与使用重定位记录计算出的新值相加。2)r_symbolnum该字段含有符号表中一个符号结构的序号值(不是字节偏移值)。链接程序在算出符号的绝对地址以后,就将该地址加到正在进行重定位的指针上。(如果r_extern比特位是0,那么情况就不同,见下面。)3)r_pcrel如果设置了该位,链接程序就认为正在更新一个指

22、针,该指针使用pc相关寻址方式,是属于机器码指令部分。当运行程序使用这个被重定位的指针时,该指针的地址被隐式地加到该指针上。4)r_length该字段含有指针长度的2的次方值:0表示1字节长,1表示2字节长,2表示4字节长。5)r_extern如果被置位,表示该重定位需要一个外部引用;此时链接程序必须使用一个符号地址来更新相应指针。当该位是0时,则重定位是“局部”的。链接程序更新指针以反映各个段加载地址中的变化,而不是反映一个符号值的变化。在这种情况下,r_symbolnum字段的内容是一个n_type值;这类字段告诉链接程序被重定位的指针指向那个段。6)r_padLinux系统中没有使用的4

23、个比特位。在写一个目标文件时最好全置0。符号将名称映射为地址(或者更通俗地讲是字符串映射到值)。由于链接程序对地址的调整,一个符号的名称必须用来表示其地址,直到已被赋予一个绝对地址值。符号是由符号表中固定长度的记录以及字符串表中的可变长度名称组成。符号表是nlist结构的一个数组,如下所示:其中各字段的含义为:1)n_un.n_strx含有本符号的名称在字符串表中的字节偏移值。当程序使用nlist()函数访问一个符号表时,该字段被替换为n_un.n_name字段,这是内存中字符串的指针。2)n_type用于链接程序确定如何更新符号的值。使用第146154行开始的位屏蔽(bitmasks)码可以将8比特宽度的n_type字段分割成三个子字段,如图14-2所示。对于N_EXT类型位置位的符号,链接程序将它们看作是“外部的”符号,并且允许其他二进制目标文件对它们的引用。N_TYPE屏蔽码用于链接程序感兴趣的比特位: N_UNDF。一个未定义的符号。链接程序必须在其他二进制目标文件中定位一个具有相同名称的外部符号

copyright@ 2008-2022 冰豆网网站版权所有

经营许可证编号:鄂ICP备2022015515号-1