78 lines
2.4 KiB
ReStructuredText
Raw Permalink Normal View History

2014-03-01 16:45:08 +08:00
使用make更新函数库文件
======================
函数库文件也就是对Object文件程序编译的中间文件的打包文件。在Unix下一般是由
命令 ``ar`` 来完成打包工作。
2014-03-01 16:45:08 +08:00
函数库文件的成员
----------------
2016-02-17 16:44:09 +08:00
一个函数库文件由多个文件组成。你可以用如下格式指定函数库文件及其组成::
2014-03-01 16:45:08 +08:00
archive(member)
这个不是一个命令,而一个目标和依赖的定义。一般来说,这种用法基本上就是为了
``ar`` 命令来服务的。如::
2014-03-01 16:45:08 +08:00
foolib(hack.o) : hack.o
ar cr foolib hack.o
2016-02-17 16:44:09 +08:00
如果要指定多个member那就以空格分开如::
2014-03-01 16:45:08 +08:00
2016-02-17 16:44:09 +08:00
foolib(hack.o kludge.o)
2014-03-01 16:45:08 +08:00
2016-02-17 16:44:09 +08:00
其等价于::
2014-03-01 16:45:08 +08:00
2016-02-17 16:44:09 +08:00
foolib(hack.o) foolib(kludge.o)
2014-03-01 16:45:08 +08:00
2016-02-17 16:44:09 +08:00
你还可以使用Shell的文件通配符来定义如::
2014-03-01 16:45:08 +08:00
2016-02-17 16:44:09 +08:00
foolib(*.o)
2014-03-01 16:45:08 +08:00
函数库成员的隐含规则
--------------------
当make搜索一个目标的隐含规则时一个特殊的特性是如果这个目标是 ``a(m)`` 形式
的,其会把目标变成 ``(m)`` 。于是,如果我们的成员是 ``%.o`` 的模式定义,并且如果
我们使用 ``make foo.a(bar.o)`` 的形式调用Makefile时隐含规则会去找 ``bar.o``
规则,如果没有定义 ``bar.o`` 的规则那么内建隐含规则生效make会去找 ``bar.c``
文件来生成 ``bar.o`` 如果找得到的话make执行的命令大致如下::
2014-03-01 16:45:08 +08:00
cc -c bar.c -o bar.o
ar r foo.a bar.o
rm -f bar.o
还有一个变量要注意的是 ``$%`` ,这是专属函数库文件的自动化变量,有关其说明请参
见“自动化变量”一节。
2014-03-01 16:45:08 +08:00
函数库文件的后缀规则
--------------------
2014-03-07 14:00:09 +08:00
你可以使用“后缀规则”和“隐含规则”来生成函数库打包文件,如:
2014-03-01 16:45:08 +08:00
.. code-block:: makefile
.c.a:
$(CC) $(CFLAGS) $(CPPFLAGS) -c $< -o $*.o
$(AR) r $@ $*.o
$(RM) $*.o
其等效于:
.. code-block:: makefile
(%.o) : %.c
$(CC) $(CFLAGS) $(CPPFLAGS) -c $< -o $*.o
$(AR) r $@ $*.o
$(RM) $*.o
2014-03-07 14:00:09 +08:00
2014-03-01 16:45:08 +08:00
注意事项
--------
在进行函数库打包文件生成时请小心使用make的并行机制 ``-j`` 参数)。如果多个
``ar`` 命令在同一时间运行在同一个函数库打包文件上,就很有可以损坏这个函数库文件
。所以在make未来的版本中应该提供一种机制来避免并行操作发生在函数打包文件上。
2014-03-01 16:45:08 +08:00
2015-11-09 11:41:27 +08:00
但就目前而言,你还是应该不要尽量不要使用 ``-j`` 参数。