linux 静态库和动态库(共享库)的制作与使用(注意覆盖问题)转

一、linux操作系统支持的函数库分支

  静态库:libxxx.a,在编译时就将库编译进可执行程序

    优点:程序的运行环境中不需要外部的函数库

    缺点:可执行程序大

  动态库:又称共享库,libxxx.so,在程序运行时将库加载到可执行程序中

    优点:可执行程序小

    缺点:程序的运行环境中必须提供相应的库

  函数库目录:/lib  /usr/lib

二、静态库的制作

  ① 生成目标文件:gcc  -c  file.c

  ② 静态库的创建命令 ar

    ar  -cr  libfile.a  file.o

    -c:Crete的意思

    -r:replace的意思,表示当插入的模块file.o已经存在libfile.a中,则覆盖。反之ar显示一个错误信息。  

  ③ 操作静态库的几个实例:

    情况1:如果从别处得到一个静态库libunknown.a,想知道其中包含哪些模块。

        命令--- ar  -t  libunknown.a

    静态库的编译:gcc  -o  main  main.c  -L.  -lfile 编译main.c 就会把静态库整合到main中。

      其中:  

        -L:指定静态函数库的位置供查找,注意L后面还有个. ,表示静态库在当前目录查找。

        -l:则指定了静态库名,由于静态函数库的命名方式是lib***.a,其中lib和 .a可以忽略不写。

  ④ 示例

   

   

   

   

三、动态库的制作

  ① 生成目标文件:gcc  -c  file.c

  ② gcc  -shared  -fpic  -o  libfile.so  file.o

     -fpic:产生位置无关代码

     -shared:生成共享库

     用上述命令生成libfile.so动态函数库。

      gcc  -o  out  main.c  -L.  -lfile

     此时还不能立即执行./out ,因为在动态函数库使用时,会默认在 /usr/lib或 /lib目录下去查找动态库,而此时我们生成的库不在里面

  ③ 示例

    

    

  第一种方法:

    libfile.so方到 /lib 或 /usr/lib中去

  第二中方法: 环境变量的方法,假设libsub.so在~/Coding/libsotest

    执行 export LD_LIBRARY_PATH=~/Coding/libsotest

       echo $LD_LIBRARY_PATH 查看路径是否添加成功

    

  第三种方法:修改sheel配置脚本

    在/etc/ld.so.conf文件里加入我们生成的库目录,然后/sbin/ldconfig

    /etc/ld.so.conf是一个非常重要的目录,里面存放的是链接器和加载器搜索共享库时要检查的目录,默认是从/usr/lib

    或/lib 中读取,所以想要顺利运行,可以把我们库的目录加入到这个文件中并执行/sbin/ldconfig

    ① 打开ld.so.conf文件    

      

    ② 向文件中添加路径

      

    ③ 用ldconfig执行sheel脚本

      

      ④ 执行可执行程序

          

四、静态库和动态库的大小比较

      

  由此可见:

      编译成功后可执行程序,静态库比较大,因为这里代码不多,所以看不到有很大差距

http://www.cnblogs.com/jiangson/p/6077171.html

posted @ 2019-07-03 09:46  mao的博客  阅读(688)  评论(0编辑  收藏  举报