make之makefile 十 函数库文件

22 篇文章 1 订阅

一、简单的静态库书写编译和测试

文件目录如下所示:

.
├── Makefile
├── MakefileTest
├── include.c
├── include.h
└── main.c

0 directories, 5 files

其中main.c函数里面会调用include.c里面的函数,所以此时的Makefile文件内容如下:

#this is a makefile demo
Main:=main
Include:=include
Libs:=libinclude.a
Libd:=libinclude.so

.PHONY:all
all:
    gcc -o $(Main) $(Main).c $(Libs)

.PHONY:lib
lib:    
    gcc -c $(Include).c
    ar rcs $(Libs) $(Include).o

.PHONY:clean
clean:
    rm -rf *.o *.a *.so

在该目录文件夹下执行

#make lib

执行后将include.c生成静态库文件libinclude.a

然后再执行

#make all

将会生成可执行文件main,生成过程中静态调用了libinclude.a静态库

 

二、以下是示例介绍

示例1、创建并使用静态库

第一步:编辑源文件,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

 

示例2:创建并使用动态库

第一步:编辑源文件,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

示例3:查看静态库中的文件

[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

三、接下来下面时介绍静态函数库文件:

创建静态库.a文件。用C/C++开发程序时经常用到,但我很少单独在命令行中使用ar命令,一般写在makefile中,有时也会在shell脚 本中用到。
  常用参数
  格式: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
  为库文件创建索引表。函数库文件也就是针对Object文件(程序编译的中间文件)的打包文件。在Unix下,通常是由命令"ar"来完成打包工作。

1、函数库文件的成员

一个函数库文件由多个文件组成。你能够以例如以下格式指定函数库文件及其组成:

archive(member)

这个不是一个命令,而是一个目标和依赖的定义。一般来说,这样的使用方法基本上就是为了"ar"命令来服务的。如:

foolib(hack.o) : hack.o
ar cr foolib hack.o

假设要指定多个member,那就以空格分开,如:

foolib(hack.o kludge.o)

其等效于:

foolib(hack.o) foolib(kludge.o)

你还能够使用Shell的文件通配符来定义,如:

foolib(*.o)


2、更新静态库

静态库.a文件都是由.o文件组成的,如果想更新静态库的话需要使用以下命令即可:

ar r libinclude.a include.o

libinclude.a是需要更新的静态库, include.o是属于静态库里面的.o文件,ar r命令就是更新静态库的.o文件的命令

执行上面的命令后,静态库文件的内容就是更新过后的最新内容了。


3、函数库文件的后缀规则

你能够使用"后缀规则"和"隐含规则"来生成函数库打包文件,如:

.c.a:
$(CC) $(CFLAGS) $(CPPFLAGS) -c $< -o $*.o
$(AR) r $@ $*.o
$(RM) $*.o

其等效于:

(%.o) : %.c
$(CC) $(CFLAGS) $(CPPFLAGS) -c $< -o $*.o
$(AR) r $@ $*.o
$(RM) $*.o


4、注意事项

在进行函数库打包文件生成时,请小心使用make的并行机制("-j"參数)。假设多个ar命令在同一时间运行在同一个函数库打包文件上,就非常有可能损坏这个函数库文件。所以,在make未来的版本号中,应该提供一种机制来避免并行操作发生在函数打包文件上。

但就眼下而言,你还是应该不要尽量不要使用"-j"參数。

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值