使用Automake生成Makefile及动态库和静态库的创建

合集下载
  1. 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
  2. 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
  3. 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。

使用Automake生成Makefile及动态库和静态库的创建使用Automake 创建和使用静态库

1. 目录结构如下:

[c-sharp]view plaincopy

1.example

2.|——src 目录(存放源代码文件)

3. |——hello.c

4.|——lib 目录(存放用来生成库的文件)

5. |——test.c 用来生成静态库libhello.a

6.|——include 目录(存放程序中使用的头文件)

7. |——hello.h

2. 编写的各个目录下的源文件

[c-sharp]view plaincopy

1.hello.h 文件

2.extern void print(char *);

3.test.c 文件

4.#include

5.void print(char *msg)

6.{

7.print(“%s/n”, msg);

8.}

9.hello.c 文件

10.#include “hello.h”

11.int main()

12.{

13.print(“Hello static library!”);//这里用到的是静态库中的函数

14.return 0;

15.}

3. 编写lib/Makefile.am 文件

[c-sharp]view plaincopy

1.noinst_LIBRARIES=libhello.a

2.libhello_a_SOURCES=test.c

3.AUTOMAKE_OPTIONS=foreign

第一行noinst 表示生成的是静态库,不需要make install ,直接制定它的位置和名字就

可以使用。

第二行表示用来生成静态库的源文件。如果要把静态库生成到其他地方,可以在=后面

加上路径(建议用绝对路径,并将所要用到的静态库生成在同一个文件夹下,如lib)。

第三行AUTOMAKE_OPTIONS 是Automake 的选项。Automake 主要是帮助开发 GNU 软

件的人员来维护软件,所以在执行Automake 时,会检查目录下是否存在标准GNU 软件中

应具备的文件,例如 'NEWS'、'AUTHOR'、 'ChangeLog' 等文件。设置为foreign 时,Automake

会改用一般软件的标准来检查。如果不加这句的话,需要在autoconf之前,先执行touch NEWS

README AUTHORS ChangeLog 来生成'NEWS'、'AUTHOR'、 'ChangeLog' 等文件4. 编写src/Makefile.am 文件

[c-sharp]view plaincopy

1.AUTOMAKE_OPTIONS=foreign

2.INCLUDES= -I../include

3.bin_PROGRAMS=hello

4.hello_SOURCES=hello.c

5.hello_LDADD=../lib/libhello.a

第二行指定头文件的位置,-I 是idirafter 的缩写。../include 指定头文件的位置,..是上

一级目录,也就是这里的example 目录。

第三行指定生成可执行文件名hello,在这里可执行文件生成在src 下,建议将可执行文

件生成到一个特定的文件夹下,让它和源代码分开,如/root/test 目录下。写法为:

[c-sharp]view plaincopy

1.bin_PROGRAMS=/root/test/hello,后面的第四、五行也相对应地变为:

2._root_test_hello_SOURCES=hello.c

3._root_test_hello_LDADD=../lib/libhello.a

第四行指定生成可执行文件hello 的源代码文件,如果hello.c 在其他目录下,需要加上

完整的路径。

第五行指定需要使用静态库的位置。

5. 生成静态库文件lib/libhello.a。

执行autoscan 生成configure.scan 文件,将它重命名为configure.in 并修改其内容。

[c-sharp]view plaincopy

1.#configure.in

2.# Process this file with autoconf to produce a configure script.

3.AC_PREREQ(2.59)

4.AC_INIT(libhello.a,1.1,[])

5.AM_INIT_AUTOMAKE

6.# Checks for programs.

7.AC_PROG_CC

8.# Checks for libraries.

9.AC_PROG_RANLIB//需要加入的内容,因为使用了静态库

10.# Checks for header files.

11.# Checks for typedefs, structures, and compiler characteristics.

12.# Checks for library functions.

13.AC_OUTPUT([Makefile])

14.AC_INIT(FILE)

该宏用来检查源代码所在路径,autoscan 会自动产生,一般无须修改它。

AM_INIT_AUTOMAKE(PACKAGE,VERSION)

这个是使用 Automake 所必备的宏,PACKAGE 是所要产生软件的名称,VERSION 是版

本编号。也可以把包和版本号等信息放在AC_INIT(FILE) 宏里。

AC_PROG_CC

检查系统可用的C 编译器,若源代码是用C 写的就需要这个宏。

AC_OUTPUT(FILE)

设置 configure 所要产生的文件,若是Makefile ,configure 便会把它检查出来的结果

填充到Makefile.in 文件后产生合适的 Makefile。后面的FILE 是一个Makefile 的输出列表,

你可以选着将要输出的Makefile 的位置和个数。建议只在src 中输出Makefile。

在lib 目录下依次执行 aclocal 、autoconf、automake

--add-missing、./configure、make,

此时在该目录下就可以看到生成的静态库文件libhello.a

6. 在src 目录下,执行autoscan 生成configure.scan 文件,将它重命名为

相关文档
最新文档