《linux下的静态库与动态库的区别,Gdb调试段错误,自动生成Makefile.pdf》由会员分享,可在线阅读,更多相关《linux下的静态库与动态库的区别,Gdb调试段错误,自动生成Makefile.pdf(7页珍藏版)》请在taowenge.com淘文阁网|工程机械CAD图纸|机械工程制图|CAD装配图下载|SolidWorks_CaTia_CAD_UG_PROE_设计图分享下载上搜索。
1、linux 下的静态库与动态库的区别 1.什么是库 在 windows 平台和 linux 平台下都大量存在着库。本质上来说库是一种可执行代码的二进制形式,可以被操作系统载入内存执行。由于 windows 和 linux 的本质不同,因此二者库的二进制是不兼容的。2.库的种类 linux 下的库有两种:静态库和共享库(动态库)。二者的不同点在于代码被载入的时刻不同。静态库的代码在编译过程中已经被载入可执行程序,因此体积较大。共享库的代码是在可执行程序运行时才载入内存的,在编译过程中仅简单的引用,因此代码体积较小。3.库存在的意义 库是别人写好的现有的,成熟的,可以复用的代码,你可以使用但要记得
2、遵守许可协议。现实中每个程序都要依赖很多基础的底层库,不可能每个人的代码都从零开始,因此库的存在意义非同寻常。共享库的好处是,不同的应用程序如果调用相同的库,那么在内存里只需要有一份该共享库的实例。4.库文件是如何产生的在 linux 下 静态库的后缀是.a,它的产生分两步 Step 1.由源文件编译生成一堆.o,每个.o 里都包含这个编译单元的符号表 Step 2.ar 命令将很多.o 转换成.a,成文静态库 动态库的后缀是.so,它由 gcc 加特定参数编译产生。例如:$gcc-fPIC-c*.c$gcc-shared-Wl,-soname,libfoo.so.1-o libfoo.so.
3、1.0*.5.库文件是如何命名的,有没有什么规范 在 linux 下,库文件一般放在/usr/lib/lib 下,静态库的名字一般为 libxxxx.a,其中 xxxx 是该 lib 的名称 动态库的名字一般为 libxxxx.so.major.minor,xxxx 是该 lib 的名称,major 是主版本号,minor 是副版本号 6.如何知道一个可执行程序依赖哪些库 ldd 命令可以查看一个可执行程序依赖的共享库,例如#ldd/bin/lnlibc.so.6=/lib/libc.so.6(040021000)/lib/ld-linux.so.2=/lib/ld-linux.so.2(04
4、0000000)可以看到 ln 命令依赖于 libc 库和 ld-linux 库 Gdb 调试段错误 1.段错误是什么 段错误是指访问的内存超出了系统给这个程序所设定的内存空间,例如访问了不存在的内存地址、访问了系统保护的内存地址、访问了只读的内存地址等等情况。2.段错误产生的原因 访问不存在的内存地址#include#include void main()int*ptr=NULL;*ptr=0;访问系统保护的内存地址#include#include void main()int*ptr=(int*)0;*ptr=100;访问只读的内存地址#include#include#include vo
5、id main()char*ptr=test;strcpy(ptr,TEST);#include 栈溢出#include void main()main();3.使用 gcc 和 gdb 调试 1 dummy_function(void)2 3 unsigned char*ptr=0 x00;4 *ptr=0 x00;5 6 7 int main(void)8 9 dummy_function();10 11 return 0;12 调试步骤 1、为了能够使用 gdb 调试程序,在编译阶段加上-g 参数 gcc-g-o test test.c 2、使用 gdb 命令调试程序:3、进入 gdb
6、后,运行程序:4、完成调试后,输入 q 命令退出 gdb:适用场景 1、仅当能确定程序一定会发生段错误的情况下使用。2、当程序的源码可以获得的情况下,使用-g 参数编译程序。3、一般用于测试阶段,生产环境下 gdb 会有副作用:使程序运行减慢,运行不够稳定,等等。4、即使在测试阶段,如果程序过于复杂,gdb 也不能处理。自动生成 Makefile 对于一个 UNIX/Linux 下 C 程序员来说,一个比较麻烦的工作就是写自己的 Makefile。可能你有如下经验:写一个简单的 C 程序,自己多写几行 gcc 命令就把程序变成可执行的了;写一个稍微复杂点的程序,源文件个数可能在 30 个左右,
7、还是写一行行的 gcc 命令就麻烦了,你可能想到写个 makefile,你可能也在这样做着;但你某一天会发现你写的这个Makefile 可能不是一个所有 UNIX/Linux 类操作系统下通用的 Makefile,比如某人下载了你的程序去他自己电脑上可能 make 不了。这样,你就有必要了解并学会运用 autoconf 和 automake 了。autoconf 是一个用于生成可以自动地配置软件源代码包以适应多种 UNIX 类系统的 shell脚本的工具。由 autoconf 生成的配置脚本在运行的时候不需要用户的手工干预;通常它们甚至不需要手工给出参数以确定系统的类型。相反,它们对软件包可能
8、需要的各种特征进行独立的测试。在每个测试之前,它们打印一个单行的消息以说明它们正在进行的检测,以使得用户不会因为等待脚本执行完毕而焦躁。因此,它们在混合系统或者从各种常见 UNIX变种定制而成的系统中工作的很好。你也省了工作,没必要维护文件以储存由各个 UNIX变种、各个发行版本所支持的特征的列表。automake 是一个从文件 Makefile.am 自动生成 Makefile.in 的工具。每个 Makefile.am基本上是一系列 make 的宏定义(make 规则也会偶尔出现)生成的 Makefile.in,服从GNU Makefile 标准。为了生成 Makefile.in,auto
9、make 需要 perl。但是由 automake 创建的发布完全服从GNU 标准,并且在创建中不需要 perl。在开始使用 autoconf 和 automake 之前,首先确认你的系统安装有 GNU 的如下软件:1.automake 2.autoconf 3.m4 4.perl 5.如果你需要产生共享库(shared library)则还需要 GNU Libtool 介绍方法之前大家看一下下面这个图,先记下 autoconf 和 automake 工作的几个步骤:步骤解释如下:1、由你的源文件通过autoscan命令生成configure.scan文件,然后修改configure.scan
10、文件并重命名为 configure.in 2、由 aclocal 命令生成 aclocal.m4 3、由 autoconf 命令生成 configure 4、编辑一个 Makefile.am 文件并由 automake 命令生成 Makefile.in 文件 5、运行 configure 命令生成 Makefile automake 支持三种目录层次:flat、shallow 和 deep。一个 flat 包指的是所有文件都在一个目录中的包。为这类包提供的 Makefile.am 不需要SUBDIRS 这个宏。这类包的一个例子是 termutils。对应咱们程序员来说:就是所有源文件及自己写的
11、头文件都位于当前目录里面,且没有子目录。一个 deep 包指的是所有的源代码都被储存在子目录中的包;顶层目录主要包含配置信息。GNU cpio 是这类包的一个很好的例子,GNU tar 也是。deep 包的顶层 Makefile.am 将包括宏 SUBDIRS,但没有其它定义需要创建的对象的宏。对应咱们程序员来说:就是所有源文件及自己写的头文件都位于当前目录的一个子目录里面,而当前目录里没有任何源文件。一个 shallow 包指的是主要的源代码储存在顶层目录中,而各个部分(典型的是库)则储存在子目录中的包。automake 本身就是这类包(GNU make 也是如此,它现在已经不使用 auto
12、make)。对应咱们程序员来说:就是主要源文件在当前目录里,而其它一些实现各部分功能的源文件各自位于不同目录。前两个层次的程序编辑方法非常简单,按照上述步骤一步步即可。而第三种层次 shallow稍微复杂一点,但这是我们经常写程序用到的结构。下面以一个例子说明 shallow 层次结构的源文件如何自动生成 Makefile 文件。例子源程序结构如下:hello 是我们的工作目录,hello 目录下有 main.c 源文件和 comm、tools、db、network、interface 等五个目录。comm 目录下有 comm.c 和 comm.h 源文件及头文件,tools目录下有 tool
13、s.c 和 tools.h,同样其它目录分别有 db.c、db.h、network.c、network.h、interface.c、interface.h 等一些源文件。按照如下步骤来自动生成 Makefile 吧:1、进入 hello 目录,运行 autoscan 命令,命令如下:cd hello autoscan 2、ls 会发现多了一个 configure.scan 文件。修改此文件,在 AC_INIT 宏之后加入AM_INIT_AUTOMAKE(hello,1.0),这里 hello 是你的软件名称,1.0 是版本号,即你的这些源程序编译将生成一个软件 hello-1.0 版。然后把
14、configure.scan 文件的最后一行AC_OUTPUT 宏填写完整变成 AC_OUTPUT(Makefile),表明 autoconf 和 automake最终将生成 Makefile 文件。最后把 configure.scan 文件改名为 configure.in。最终 configure.in 文件内容如下:#-*-Autoconf-*-#Process this file with autoconf to produce a configure script.AC_PREREQ(2.60)AC_INIT(FULL-PACKAGE-NAME,VERSION,BUG-REPORT-A
15、DDRESS)AM_INIT_AUTOMAKE(client,1.0)AC_CONFIG_SRCDIR(client.c)#AC_CONFIG_HEADER(config.h)#如果这行不注释掉会有问题为什么我也不知道#Checks for programs.AC_PROG_CC#Checks for libraries.#Checks for header files.AC_CHECK_HEADERS(netdb.h netinet/in.h strings.h sys/socket.h unistd.h)#Checks for typedefs,structures,and compile
16、r characteristics.AC_HEADER_TIME#Checks for library functions.AC_HEADER_STDC AC_FUNC_SELECT_ARGTYPES AC_CHECK_FUNCS(bzero gethostbyname select socket)AC_OUTPUT(Makefile)3、运行 aclocal 命令,ls 会发现多了一个 aclocal.m4 文件。4、然后运行 autoconf 命令,ls 将发现生成了一个可执行的 configure 命令。5、编辑一个 Makefile.am 文件,文件内容如下:AUTOMAKE_OPTI
17、ONS=foreign bin_PROGRAMS=hello hello_SOURCES=main.c comm/comm.c comm/comm.h tools/tools.c tools/tools.h db/db.c db/db.h network/network.c network/network.h interface/interface.c interface/interface.h 这表明你最后将通过一个 make命令利用上述 hello_SOURCES 源文件生成一个 hello 的程序。6、运行 automake-add-missing 命令。屏幕提示如下:automake:
18、configure.in:installing./install-sh automake:configure.in:installing./mkinstalldirs automake:configure.in:installing./missing 7、然后你可以运行之前生成的configure命令来生成一个 Makefile文件,输入./configure命令即可。8、编辑 Makefile 文件,找到$(LINK)所在的那一行,本来生成的文件内容如下:rm-f hello$(LINK)$(hello_LDFLAGS)$(hello_OBJECTS)$(hello_LDADD)$(LIBS
19、)在这两行之间增加几行变成:rm-f hello mv-f comm.o comm mv-f tools.o tools mv-f db.o db mv-f network.o network mv-f interface.o interface$(LINK)$(hello_LDFLAGS)$(hello_OBJECTS)$(hello_LDADD)$(LIBS)这是因为默认生成的 Makefile 将在编译后把所有目标文件置于当前目录,而在进行链接(link)时又会到各个子目录去找相应的目标文件。当然,为了完整,建议各位在 clean 部分加上如下一些行:rm-f comm/comm.o r
20、m-f tools/tools.o rm-f db/db.o rm-f network/network.o rm-f interface/interface.o 好了,经过上述这些步骤后,现在你可以来编译生成你自己的可执行程序了。输入一个 make all 吧,然后就可以运行./hello 来看你的程序运行了。运用 autoconf 和 automake 的最大好处是,你的程序以源程序方式发布后,其它所有人只需要依次输入./configure make make install 命令就可以把你的程序安装在自己的电脑上运行了。所有符合 GNU 标准的 UNIX/Linux都不需要再修改 Makefile 里的任何字符。(http:/