linux下静态库和动态库创建和使用

linux静态库 .a  ===== win 静态库 .lib

linux动态库 .so   ====  win动态库  .dll 

(1)----静态库生成过程:

        --  原材料 :源码.c文件或.cpp文件

        ----第一步:将.c文件生成.o文件:gcc   *.c  -c 

        ----第二步:将.o文件打包: ar rcs  静态库名字   *.o文件

                         (静态库名字 =  libmytest.a):三部分,前缀,名字,后缀

       -----ar   rcs  libmytest.a  *.o

查看库内容  nm  libmytest.a

查看app内容  file  app

到此,一个静态库就创建成功了。

(2)------静态库的使用:

调用静态库文件假设为libtest.c

gcc  -I  ./include  -L ./lib  -lmytest

-L : 大l 指定库的路径

-l :小l 指定库的名字(去掉前缀和后缀)

-I :大i  :指定头文件路径

如果想指定生成的可执行文件的名字,用-o指定文件名,gcc  -I  ./include  -L ./lib  -lmytest  -o app

(3)-------动态库的产生:

----原材料:源代码.c/.cpp文件

-----第一步:将源文件生成.o文件: gcc  *.c  -c  fpic(fPIC)

-----第二步:打包:  gcc  -shared  *.o  -o  libmytest.so

(4)-----动态库的使用:

同静态库:gcc  test.c -c -I./include  -L ./lib  -lmytest  -o app

运行app报错:mytest  not found

(5)-----动态库无法加载原因:命令ldd  app看到libmytest.so显示找不到此动态库。

动态链接器ld_linux_x86_64.so查找动态库先后顺序:

1.   LD_LIBRARY_PATH,环境变量

2.   /etc/ld.so.cache文件列表

3.   /lib

4.  /usr/lib

当以上4个位置都检查不到那个动态库文件时候就会报错!

(6)-----解决办法:

---------1, 将.so文件拷贝到/lib或者/usr/lib下(不推荐,可能会和已有的库名字冲突而覆盖掉原来文件)。

--------2, 修改LD_LIBRARY_PATH环境变量(推荐)

        ------临时修改(当前终端有效):

                export LD_LIBRARY_PATH = 动态库路径 : $LD_LIBRARY_PATH

         --------永久修改

                    ===用户级别:(当前用户生效)

                               修改~/.bashrc文件,完成后重启终端或者source ~/.bashrc

                     ===系统级别:(所有用户生效)

                                修改./etc/profile文件,安成后重启终端或者source ./etc/profile

                                source可用.代替。

--------------3. 修改ld.so.cache列表

将动态库的绝对路径写入到/etc/ld.sl.conf中,

完成后执行 ldconfif -v(-v参数展示终端输出内容)

(7)----静态库动态库对比:

     ====静态库将.a文件中相关的.o文件与调用这个静态库编译后的.o文件一起组成可执行文件。

1. 由于静态库已经被打包进可执行程序文件中,所以加载起来会速度很快,发布程序不需要提供静态库,移植方便。这同时就导致了更新发布复杂。同时静态库浪费系统资源,消耗内存。

2. 程序一开始运行,静态库就被加载到内存了。  

    ====动态库是没有打包进可执行程序的,只是记录了用到哪个库里的哪个函数,运行程序的时候动态库也不会被加载,当程序调用动态库里面的函数的时候,动态库才会被加载到内存。

程序运行之前先检查动态库是否存在,通过动态链接器ld _linux_x86_64.so检查器检查动态库是否存在。

你可能感兴趣的:(linux下静态库和动态库创建和使用)