Linux中的静态库、共享库、头文件及makefile文件举例

库:是一组预先编译好的函数的集合,linux中标准系统库文件一般存储在/lib/usr/lib目录中

静态库:在程序编译过程中,就被链接到了程序编写者所写的源代码中,静态库以.a结束。

共享库:在程序运行时载入,编译时只需说明所需要的共享库文件即可。共享库以.so接受。

头文件:用于保存程序的声明。

makefile文件:makefile带来的好处就是——“自动化编译”,一旦写好各文件的依赖项及其编译方式,只需要一个make命令,整个工程完全自动编译,极大的提高了软件开发的效率。

一.共享库示例:

1、在bill.h头文件中,写函数求数组最大元素的函数声明;

***@ubuntu:~/codeC/1201B$ more bill.h
int bill(int a[], int n);

2、在bill.c文件中引入头文件,写该函数的实现;

***@ubuntu:~/codeC/1201B$ more bill.c
#include "bill.h"
int bill(int a[], int n)
{
    int i,max = a[i];
    for( i = 0; i < n; ++i)
    {
        if( max < a[i])
        {
            max = a[i];
        }
    }
    return max;
}
3、在main.c中写主程序内容,调用该函数,此时,需要引入头文件

***@ubuntu:~/codeC/1201B$ more main.c
#include <stdio.h>
#include "bill.h"
int main()
{
    int MAX;
    int ar[10] = {1,23,21,34,45,56,57,48,90,100};
    MAX = bill(ar,10);
    printf("%d\n",MAX);
    return 0;
}

4、编译共享库以及main.c;
***@ubuntu:~/codeC/1201B$ gcc -shared -fPIC bill.c -o libbill.so

结果如下:

***@ubuntu:~/codeC/1201B$ ls
bill.c  bill.h  libbill.so  main.c

5、设置环境变量(未设置环境变量,则系统只在默认的标准路径下寻找共享库,设置了环境变量之后,则系统首先在环境变量指定的路径下寻找共享库)

/*此环境变量的设置只是对于共享库而言*/
***@ubuntu:~/codeC/1201B$ export LD_LIBRARY_PATH=./

6、编译生成可执行程序/* 其中-L.表示库文件的查找路径为当前路径(.),-lbill表示所要使用的文件共享库文件名为bill

头文件由于处于当前路径,故可以省略不写,当处于系统标准路径时也可省略不写*/
***@ubuntu:~/codeC/1201B$ gcc -o main main.c -L. -lbill

7、编译成功,执行main程序
***@ubuntu:~/codeC/1201B$ ls
bill.c  bill.h  libbill.so  main  main.c
***@ubuntu:~/codeC/1201B$ ./main
100


二.共享库的makefile:

仍然上面为例子:

1、上例中源代码为:

***@ubuntu:~/codeC/1201B$ ls
bill.c  bill.h  main.c  makefile


2、makefile文件如下:

***@ubuntu:~/codeC/1201B$ more makefile
main: main.o libbill.so 
export LD_LIBRARY_PATH=./
gcc -o main main.c -L. -lbill
main.o: main.c bill.h
gcc -c main.c
libbill.so: bill.c
gcc -shared -fPIC bill.c -o libbill.so

3、make的过程:

***@ubuntu:~/codeC/1201B$ make
gcc -shared -fPIC bill.c -o libbill.so
export LD_LIBRARY_PATH=./
gcc -o main main.c -L. -lbill

4.执行结果为:

***@ubuntu:~/codeC/1201B$ ./main

100
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
############################################################################# # Makefile for building: sample 2011-09-26 # # Project: # Template: # Command: # ------基本上简单用法的makefile------- #1. 第一个目标为最终目标 #2. 命令以 Tab开头,可以有多个命令 #3. 分行号\ 后面不可以跟空格 #4、加@可以去掉命令显示 #5. 变量为 abc = efd 访问为 $(abc) echo $abc # # # #缺点,单文件夹 #每次都会重新生成 # #foo.o : foo.c defs.h # foo模块 #cc -c -g foo.c # #多目录 一种方法,在主目录里面include "",然后其里面OBJS += .o,这样其实就是 或用foreach ############################################################################# #target EXECUTABLE := test CC := gcc CXX := g++ STRIP := strip AR := ar cqs LINK := g++ RM := rm -f CFLAGS := -g -Wall CXXFLAGS := $(CFLAGS) CXXFLAGS += -MD LIBS := -lm LIBPATH := -L/usr/local/lib INCPATH := ####### Output directory OBJSPATH := ../Obj/ EXECUTABLEPATH := ../Execute/ #######source Files SOURCE := $(wildcard *.c) $(wildcard *.cpp) OBJS := $(patsubst %.c, %.o, $(patsubst %.cpp, %.o, $(SOURCE))) DEPS := $(patsubst %.o,%.d,$(OBJS)) #######rule .SUFFIXES: .cpp .c .o .so .a .d $(OBJSPATH)%.o:%.c $(CC) $(CFLAGS) -c $< -o $@ $(OBJSPATH)%.o:%.cpp $(CXX) $(CXXFLAGS) -c $< -o $@ $(OBJSPATH)%.d:%.cpp $(CXX) -MM $ $@ ######main .PHONY : all deps objs clean rebuild all: $(EXECUTABLE) $(CXX) $(CXXFLAGS) $(INCLUDEPATH) $(LIBS) $(LIBPATH) $(addprefix $(OBJSPATH),$(OBJS)) \ -o $(EXECUTABLEPATH)$(EXECUTABLE) deps: $(addprefix $(OBJSPATH),$(DEPS)) objs: $(addprefix $(OBJSPATH),$(OBJS)) clean: @$(RM) $(OBJSPATH)*.o @$(RM) $(OBJSPATH)*.d @$(RM) $(EXECUTABLEPATH)$(EXECUTABLE) rebuild: clean all -include $(addprefix $(OBJSPATH),$(DEPS)) ##.d里面是详细的.o rule 自己会括展开的,然后没有文件就自己去重建 $(EXECUTABLE) : objs

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值