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;

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

  1. Android NDK入门实例 计算斐波那契数列二生成.so库文件

    上一篇文章输生成了jni头文件,里面包含了本地C代码的信息,提供我们引用的C头文件.下面实现本地代码,再用ndk-build编译生成.so库文件.由于编译时要用到make和gcc,这里很多人是通过安装 ...

  2. IOS 生成静态库文件(.framework)

    http://blog.csdn.net/zwl492454828/article/details/55095422

  3. IOS 生成静态库文件(.a文件)

    http://www.cnblogs.com/lyy-5518/p/5459643.html

  4. linux 静态库文件

    1.生成目标文件 gcc -o mylib.o -c mylib.c 2.生成静态库文件 ar rcs libmylib.a mylib.o 查看库信息: nm libmylib.a //====== ...

  5. Ubuntu下通过makefile生成静态库和动态库简单实例

    本文转自http://blog.csdn.net/fengbingchun/article/details/17994489 Ubuntu环境:14.04 首先创建一个test_makefile_gc ...

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

    问题描述 利用toolchian.cmake设置好编译器后,利用make指令生成静态库,出现以下问题 Error running link command: No such file or direc ...

  7. Makefile 编译静态库文件及链接静态库

    本文为原创文章,转载需指明该文链接 1.代码目录结构如下: comm/ comm/inc/apue.h  3 atexit.c Makefile  5 staticlib/lib/ staticlib ...

  8. 生成静态库.a文件和动态库.so文件

    转载来源:https://www.cnblogs.com/hookjc/ 静态库 在linux环境中, 使用ar命令创建静态库文件.如下是命令的选项: d -----从指定的静态库文件中删除文件 m ...

  9. 在Linux下如何使用GCC编译程序、简单生成 静态库及动态库

      最近在编写的一个Apache  kafka 的C/C++客户端,,在看他写的 example中,他的编译是用librdkafka++.a和librdkafka.a    静态库编译的,,,而我们这 ...

随机推荐

  1. webstock学习

    1.WebSocket是HTML5中出出现的新技术,有着web TCP之称,这也是为了适应现在实时传输数据的趋势,在这之前一般采用两种方法进行实时数据交换. 轮询机制,其中又包括长轮询. ①短轮询是指 ...

  2. 公司开发部门GIT与SVN 之争

    公司最开始决定是使用GIT作为版本控制 , 也都使用了4,5个月了 , 开发人员也都是20多岁年轻力壮的年轻人 , 每个组的组长也一直在做git使用的培训 , 即使是这样 , 还是遇到了非常大的阻碍 ...

  3. 前端经典面试题 不经典不要star!

    前言 (以下内容为一个朋友所述)今天我想跟大家分享几个前端经典的面试题,为什么我突然想写这么一篇文章呢?今天我应公司要求去面试了下几位招聘者,然后又现场整不出几个难题,就搜了一下前端变态面试题! HA ...

  4. Somethings about Floors题解

    题目内容:一个楼梯有N级(N >=0), 每次走1级或2级, 从底走到顶一共有多少种走法? 输入要求:只有一行输入,并且只有一个数N(如果N > 20,则N = N%21,即保证N的范围控 ...

  5. ssh框架出现Java.lang.NoSuchMethodError: antlr.collections.AST.getLine()I错误

    原因:因为Struts自带的antlr-2.7.2.jar,比Hibernate自带的antlr-2.7.7.jar的版本要低,存在jar包冲突现象,因此要删除前一个低版本的. 由于myeclipse ...

  6. 转:android 屏幕适配小结

    做android开发,开源嘛,满市场都是凌乱的机型,总少不了适配这样或那样的型号.在这里分享一下自己在开发中用到的方法. 首先要介绍一下drawable-mdpi.drawable-hdpi-1280 ...

  7. 你不知道的HTTP之首部字段一览

    一.HTTP/1.1 首部字段一览 HTTP 首部字段根据实际用途被分为以下 4 种类型: 1.通用首部字段:请求报文和响应报文两方都会使用的首部. 首部字段名 说明 Cache-Control 控制 ...

  8. 目后佐道IT教育的品牌故事

    关于目后佐道 目后佐道IT教育作为中国IT职业教育领导品牌,致力于HTML5.UI.PHP.Java+大数据.Python+人工智能.Linux.产品经理.测试.运维等课程培训.100%全程面授,平均 ...

  9. 获取CPU相关信息

    实现效果: 知识运用:  WMI管理类中的ManagementObjectCollection类    ManagementObjectSearcher类的Get方法  和ManagementObje ...

  10. chosen选择框加载数据

    1.单选$(select).val($("#id").val());$(select).trigger("chosen:updated"); 2.多选 func ...