linuxar命令用法,Linux命令详解

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

Linux makefile&shell的一个问题

ar 命令是用来将若干 .o 文件打包成(静态)库文件。 按照习惯,库文件后缀名都是 .a

crv 分别是 ar 命令的三个参数,cr的意思是创建指定.a文件(如果不存在),并将.o文件加入到这个.a文件中。 v 的意思是让 ar 命令在执行的时候打印更多的提示信息。

ar crv abc.a $(OBJ) 就是将 abc.o 打包到库文件 abc.a 中的意思。

更多信息可以 man ar 来看到。

怎样用ar命令将库文件释放到指定路径下

用途说明

创建静态库。a文件。用C/C++开发程序时经常用到,但我很少单独在命令行中使用ar命令,一般写在makefile中,有时也会在shell脚 本中用到。关于Linux下的库文件、静态库、动态库以及怎样创建和使用等相关知识,参见本文后面的相关资料【3】《关于Linux静态库和动态库的分析》。

常用参数

格式:ar rcs libxxx.a xx1.o xx2.o

参数r:在库中插入模块(替换)。当插入的模块名已经在库中存在,则替换同名的模块。如果若干模块中有一个模块在库中不存在,ar显示一个错误消息,并不替换其他同名模块。默认的情况下,新的成员增加在库的结尾处,可以使用其他任选项来改变增加的位置。【1】

参数c:创建一个库。不管库是否存在,都将创建。

参数s:创建目标文件索引,这在创建较大的库时能加快时间。(补充:如果不需要创建索引,可改成大写S参数;如果。a文件缺少索引,可以使用ranlib命令添加)

格式:ar t libxxx.a

显示库文件中有哪些目标文件,只显示名称。

格式:ar tv libxxx.a

显示库文件中有哪些目标文件,显示文件名、时间、大小等详细信息。

格式:nm -s libxxx.a

显示库文件中的索引表。

格式:ranlib libxxx.a

为库文件创建索引表。

使用示例

示例一 在shell脚本中使用

Bash代码

OS=`uname -r`

ar rcs libhycu.a.$OS *.o

示例二 在makefile中使用

Makefile代码

$(BIN1): $(BIN1_OBJS)

ar rcs $@ $^

示例三 创建并使用静态库

第一步:编辑源文件,test.h test.c main.c。其中main.c文件中包含main函数,作为程序入口;test.c中包含main函数中需要用到的函数。

vi test.h test.c main.c

第二步:将test.c编译成目标文件。

gcc -c test.c

如果test.c无误,就会得到test.o这个目标文件。

第三步:由。o文件创建静态库。

ar rcs libtest.a test.o

第四步:在程序中使用静态库。

gcc -o main main.c -L. -ltest

因为是静态编译,生成的执行文件可以独立于。a文件运行。

第五步:执行。

./main

示例四 创建并使用动态库

第一步:编辑源文件,test.h test.c main.c。其中main.c文件中包含main函数,作为程序入口;test.c中包含main函数中需要用到的函数。

vi test.h test.c main.c

第二步:将test.c编译成目标文件。

gcc -c test.c

前面两步与创建静态库一致。

第三步:由。o文件创建动态库文件。

gcc -shared -fPIC -o libtest.so test.o

第四步:在程序中使用动态库。

gcc -o main main.c -L. -ltest

当静态库和动态库同名时,gcc命令将优先使用动态库。

第五步:执行。

LD_LIBRARY_PATH=. ./main

示例五 查看静态库中的文件

[root@node56 lib]# ar -t libhycu.a

base64.c.o

binbuf.c.o

cache.c.o

chunk.c.o

codec_a.c.o

xort.c.o

[root@node56 lib]#

[root@node56 lib]# ar -tv libhycu.a

rw-r--r-- 0/0 7220 Jul 29 19:18 2011 base64.c.o

rw-r--r-- 0/0 2752 Jul 29 19:18 2011 binbuf.c.o

rw-r--r-- 0/0 19768 Jul 29 19:18 2011 cache.c.o

rw-r--r-- 0/0 4580 Jul 29 19:18 2011 xort.c.o

[root@node56 lib]#

[root@node56 lib]# nm -s libhycu.a | less

Archive index:

Base64Enc in base64.c.o

GetBase64Value in base64.c.o

Base64Dec in base64.c.o

encode64 in base64.c.o

decode64 in base64.c.o

check64 in base64.c.o

test64 in base64.c.o

chunk_alloc in chunk.c.o

[root@node56 lib]#


网站名称:linuxar命令用法,Linux命令详解
URL链接:http://myzitong.com/article/dssphes.html