Makefile学习(二)----生成静态库文件

Lunix下编译静态库文件:

.o后缀文件:编译生成的中间代码文件;

.a后缀文件:静态库文件,编译的时候会合到可执行程序中,文件比较大;

.so后缀文件:动态库文件,只是一个指向,不会合到可执行程序中,当要调用函数库的时候才使用;

用一个简单的例子阐述下在lunix环境下生成静态库文件的过程:

一.   源码文件:

so_test.h:

void test_a();

void test_b();

void test_c();

test_a.c:

#include "so_test.h"

void test_a()

{

printf("this is in test_a...\n");

}

test_b.c:

#include "so_test.h"

void test_a()

{

printf("this is in test_b...\n");

}

test_c.c:

#include "so_test.h"

void test_a()

{

printf("this is in test_c...\n");

}

test.c:

#include "so_test.h"

int main()

{

test_a();

test_b();

test_c();

return 0;

}

二.   makefile 文件:

makefile:

SHELL = /bin/sh

LIB_DIR = /cbs/lhbb/hcj/dy/lib/

BIN_DIR = /cbs/lhbb/hcj/dy/bin/

OBJECT_DIR = /cbs/lhbb/dy/test/obj/

APP_DIR = /cbs/lhbb/hcj/dy/testapp/

$(shell mkdir -p ${LIB_DIR})

$(shell mkdir -p ${BIN_DIR})

$(shell mkdir -p ${OBJECT_DIR})

RM = rm -fr

#****************************************************************************

CC = gcc

AR = ar rc

SRC_OBJECT = $(APP_DIR)test_a.c $(APP_DIR)test_b.c $(APP_DIR)test_c.c

H_OBJECT = $(APP_DIR)so_test.h

OBJECT = test_a.o test_b.o test_c.o

DY_SRC_OBJECT = $(APP_DIR)test.c

DY_OBJECT=test.o

LIB_OBJECT = libtest.a

BIN_OBJECT = test

#****************************************************************************

.PHONY:all

all:$(LIB_OBJECT) $(BIN_OBJECT)

$(LIB_OBJECT):$(OBJECT)

$(AR) $(LIB_OBJECT) $(OBJECT)

mv $(LIB_OBJECT) $(LIB_DIR)

$(OBJECT):$(SRC_OBJECT) $(H_OBJECT)

$(CC) -c $(SRC_OBJECT)

$(BIN_OBJECT):$(DY_OBJECT)

$(CC) -o $(BIN_OBJECT) $(OBJECT_DIR)$(DY_OBJECT) $(LIB_DIR)$(LIB_OBJECT)

mv $(BIN_OBJECT) $(BIN_DIR)

$(DY_OBJECT):$(DY_SRC_OBJECT)

$(CC) -c $(DY_SRC_OBJECT) -o $(DY_OBJECT)

mv $(OBJECT) $(DY_OBJECT) $(OBJECT_DIR)

clean:

$(RM) $(LIB_DIR) $(BIN_DIR) $(OBJECT_DIR)

三.makefile文件的简单阐述:

1. 路径变量赋值:

LIB_DIR = /cbs/lhbb/hcj/dy/lib/          -----存放生成的静态库文件,.a文件;

BIN_DIR = /cbs/lhbb/hcj/dy/bin/         -----存放生成的可执行文件;

OBJECT_DIR = /cbs/lhbb/dy/test/obj/     -----存放生成的中间代码文件,.o文件;

APP_DIR = /cbs/lhbb/hcj/dy/testapp/     -----存放源文件;

2.调用shell脚本,创建目录:

$(shell mkdir -p ${LIB_DIR})

$(shell mkdir -p ${BIN_DIR})

$(shell mkdir -p ${OBJECT_DIR})

3.编译变量赋值:

RM = rm –fr

CC = gcc

AR = ar rc       -----生成静态库文件命令

4.文件变量赋值:

SRC_OBJECT = $(APP_DIR)test_a.c $(APP_DIR)test_b.c $(APP_DIR)test_c.c

----源文件变量;

H_OBJECT = $(APP_DIR)so_test.h

----头文件变量;

OBJECT = test_a.o test_b.o test_c.o

----中间代码文件变量;

DY_SRC_OBJECT = $(APP_DIR)test.c

----生成test可执行文件所依赖的源文件变量;

DY_OBJECT=test.o

----编译test.c生成的中间代码文件变量;

LIB_OBJECT = libtest.a

----静态库文件变量;

BIN_OBJECT = test

----生成的可执行文件变量;

这个makefile中基本都是使用的变量,这样编译不同的工程的时候,就只要修改变量的值,编译的整体框架就不需要修改,当然,这个框架只是本人刚开始研究makefile写的,不够好,望大神吐槽,谢谢!

5.编译主体阐述:

.PHONY:all

----固定用.PHONY定义一个伪目标,伪目标不是文件,只是一个标签,没有依赖文件;这边定义了一个伪目标all;

all:$(LIB_OBJECT) $(BIN_OBJECT)

----目标all包含了两个需要生成的目标文件,一个是需要生成的静态库文件libtest.a,一个是最终生成的可执行文件test;但是为什么这边需要用一个all来包含两个目标文件呢?原因是通常情况下,系统只会去编译生成makefile文件开头最早一个目标文件,下面的目标文件是不会去执行编译的,所以我在这边将两个目标文件写在了一个伪目标all中,这样就可以实现生成两个目标文件;

生成静态库文件的过程:

$(LIB_OBJECT):$(OBJECT)      -----目标文件:依赖文件    libtest.a:test_a.o test_b.o test_c.o

$(AR) $(LIB_OBJECT) $(OBJECT)    ----编译生成静态库文件命令,特点就是需要使用

                        ar rc命令去编译;

mv $(LIB_OBJECT) $(LIB_DIR)      ----将生成的文件移动到对应的文件夹;

$(OBJECT):$(SRC_OBJECT) $(H_OBJECT)

$(CC) -c $(SRC_OBJECT)

生成可执行文件test的过程:

$(BIN_OBJECT):$(DY_OBJECT)

$(CC) -o $(BIN_OBJECT) $(OBJECT_DIR)$(DY_OBJECT) $(LIB_DIR)$(LIB_OBJECT)

-----将静态库文件包含在命令中;

mv $(BIN_OBJECT) $(BIN_DIR)

$(DY_OBJECT):$(DY_SRC_OBJECT)

$(CC) -c $(DY_SRC_OBJECT) -o $(DY_OBJECT)

mv $(OBJECT) $(DY_OBJECT) $(OBJECT_DIR)

执行make clean删除生成的文件:

clean:

$(RM) $(LIB_DIR) $(BIN_DIR) $(OBJECT_DIR)

四.注意点:

1.命令行必须以tab键打头,否则会报错;

2.生成静态库文件用命令:ar rc;

3.库文件以lib打头,.a为后缀;

五.执行结果:

bin文件夹中存放可执行文件test,运行./test结果如下:

this is in test_a...

this is in test_b...

this is in test_c...

lib文件夹下存放生成的静态库文件libtest.a;

原文地址:https://www.cnblogs.com/Lxk0825/p/9935758.html

时间: 2024-12-22 09:32:22

Makefile学习(二)----生成静态库文件的相关文章

Ubuntu下makefile及gcc生成静态库动态库的简单使用举例

环境:Ubuntu-13.10  32位(虚拟机).gcc4.8.1 首先创建一个test_makefile_gcc文件夹,此test_makefile_gcc文件夹下包括:src文件夹用于存放源文件: include文件夹用于存放头文件:bin文件夹用于存放生成的动态库.so文件:lib文件夹用于存放生成的静态库.a文件:project_makefile文件夹存放此工程的makefile文件:test文件夹存放用来测试静态库和动态库的源文件:另外在test_makefile_gcc文件夹下还包

iOS项目引用静态库文件.a

由于开发的项目中使用了静态库文件(.a文件),因此专门对它进行了简单的学习.静态库文件包装的是经常使用的公共代码,便于代码的复用. 1.生成静态库文件(static library file).主要包括以下几个主要步骤: (1)创建静态库项目 命名为Stone,并在生成的Stone类里面添加一个类方法+printInfo,如图: 未编译前,Products文件夹下的libStone.a是红色的,编译之后变为黑色,如图: 注意顶部选择"iOS device"生成用于真机的静态库文件,选择

cmake利用toolchain.cmake生成makefile之后,make生成静态库失败问题

问题描述 利用toolchian.cmake设置好编译器后,利用make指令生成静态库,出现以下问题 Error running link command: No such file or directory 出错原因,toolchain.cmake文件内没有声明静态库生成器AR:解决方式,在toolchian.cmake文件内添加下面的声明 SET(CMAKE_AR $(TOOLCHAIN_DIR)/bin/arm-linux-gnueabihf-ar CACHE FILEPATH "Arch

一个可以自动生成静态库,自动安装程序的Makefile

.PHONY:clean install CC=g++ CFLAGS=-Wall -g BIN=libecho.a INCLUDE=echo SRC=src OBJS=Socket.o Rio.o TcpConnection.o PollPoller.o InetAddress.o TcpServer.o Thread.o Condition.o ThreadPool.o Exception.o Timer.o TimerThread.o STARD=-std=c++0x -rdynamic $

项目架构基础之二 ---- 工程中创建静态库文件(.a)库文件

步骤1.创建工程HLStaticTest 步骤2.创建静态库文件 步骤3. 关闭HLStatic,回到HLStaticTest Targets - >Build Phases ->Link Binary With Libraries 然后进入到  Targets -> Build Setting ->Header Search Paths 步骤 4. 进入AppDelegate 工程中创建静态库文件(.a)库文件 成功 版权声明:本文为博主原创文章,未经博主允许不得转载.

[转]Linux下用gcc/g++生成静态库和动态库(Z)

Linux下用gcc/g++生成静态库和动态库(Z) 2012-07-24 16:45:10|  分类: linux |  标签:链接库  linux  g++  gcc  |举报|字号 订阅 在 linux 下,库文件一般放在 /usr/lib 和 /lib 下, 静态库的名字一般为 libxxxx.a ,其中 xxxx 是该 lib 的名称 动态库的名字一般为 libxxxx.so.major.minor , xxxx 是该 lib 的名称, major 是主版本号, minor 是副版本号

ndk学习7: 使用静态库

目录: 手工编译静态库 ndk-build编译静态库 ? 手工编译静态库 老规矩还是先手工操作,知其然并知其所以然 ? 需要用到的核心命令: gcc –g –c mod1.c mod2.c mod3.c ? ? ? ? ? ? ? ? ?编译obj (debug版) ? ?? AR ?r libdemo.a mod1.o mod2.o mod3.o ? ? ? 将3个obj 添加到libdemo.a中 AR ?tv libdemo.a ? ? ? ? ? ? ? ? ? ? ? ? ? ? ?

C++生成静态库

//StaticMath.h #include <iostream> class StaticMath { public: //StaticMath(void); //~StaticMath(void); static double add(double a, double b);//加法 void print(); }; //StaticMath.cpp #include "StaticMath.h" double StaticMath::add(double a, do

由动态库文件dll生成lib库文件

本文基于OpenBlas的编译和安装.来说明怎样从一个dll文件生成lib库文件. 參考OpenBlas的说明"Howto generate import library for MingW",和MinGW的说明HOWTO Create an ImportLibrary for a DLL using MinGW,学习怎样生成lib库.当中OpenBlas的说明讲的是怎样使用Visual studio的lib.exe工具从dll生成lib文件,而MinGW讲的是怎样把一个windows