linux怎么静态编译

linux怎么静态编译,第1张

关于在 Linux 环境下面对 C 语言源程序进行静态编译,关键是要看你的 C 语言源程序中都使用到了哪些系统库函数?如果是标准的输入、输出库函数,只要在命令行提示符 $ 下面执行:

gcc my_prog.c 即可(缺省的可执行文件名是:a.out);如果在用户的源程序中使用到了数学计算函数,那么在命令行提示符 $ 下面必须执行:

gcc my_prog.c -IMATH.LIB(假设涉及到各种数学计算的数学库的库文件为:MATH.LIB)

如果不加上 -IMATH.LIB 选项,那么即使你的源程序编写得再正确,也无法正常编译。

另外还有一个必须要注意的就是:在 Linux 的环境变量中,一定要把 INCLUDE、LIB 所在的路径设置好(在 SHELL 文件中写好),这样在使用 Linux 系统时才能够减少出错的机会。

linux库有动态与静态两种,动态通常用.so为后缀,静态用.a为后缀。例如:libhello.so

libhello.a

为了在同一系统中使用不同版本的库,可以在库文件名后加上版本号为后缀,例如:

libhello.so.1.0,由于程序连接默认以.so为文件后缀名。所以为了使用这些库,通常使用建立符号连接的方式。

ln

-s

libhello.so.1.0

libhello.so.1

ln

-s

libhello.so.1

libhello.so

动态库和静态库的区别:

当要使用静态的程序库时,连接器会找出程序所需的函数,然后将它们拷贝到执行文件,由于这种拷贝是完整的,所以一旦连接成功,静态程序库也就不再需要了。然而,对动态库而言,就不是这样。动态库会在执行程序内留下一个标记‘指明当程序执行时,首先必须载入这个库。由于动态库节省空间,linux下进行连接的缺省 *** 作是首先连接动态库,也就是说,如果同时存在静态和动态库,不特别指定的话,将与动态库相连接。

两种库的编译产生方法:

第一步要把源代码编绎成目标代码。以下面的代码hello.c为例,生成hello库:

/*

hello.c

*/

#include

void

sayhello()

{

printf("hello,world\n")

}

用gcc编绎该文件,在编绎时可以使用任何全法的编绎参数,例如-g加入调试代码等:

gcc

-c

hello.c

-o

hello.o

1.连接成静态库

连接成静态库使用ar命令,其实ar是archive的意思

$ar

cqs

libhello.a

hello.o

2.连接成动态库

生成动态库用gcc来完成,由于可能存在多个版本,因此通常指定版本号:

$gcc

-shared

-wl,-soname,libhello.so.1

-o

libhello.so.1.0

hello.o

另外再建立两个符号连接:

$ln

-s

libhello.so.1.0

libhello.so.1

$ln

-s

libhello.so.1

libhello.so

这样一个libhello的动态连接库就生成了。最重要的是传gcc

-shared

参数使其生成是动态库而不是普通执行程序。

-wl

表示后面的参数也就是-soname,libhello.so.1直接传给连接器ld进行处理。实际上,每一个库都有一个soname,当连接器发现它正在查找的程序库中有这样一个名称,连接器便会将soname嵌入连结中的二进制文件内,而不是它正在运行的实际文件名,在程序执行期间,程序会查找拥有

soname名字的文件,%b


欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/yw/7620011.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-04-07
下一篇 2023-04-07

发表评论

登录后才能评论

评论列表(0条)

保存