zoukankan      html  css  js  c++  java
  • 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

  • 相关阅读:
    正则表达式---用户验证
    最短路 Dijkstra
    最短路 Dijkstra+堆优化
    LCIS(最长公共上升子序列)
    最小生成树 Kruskal
    网络流 最大流
    网络流 最小费用最大流
    树链剖分
    树状数组
    双重Hash
  • 原文地址:https://www.cnblogs.com/mwl523/p/11124564.html
Copyright © 2011-2022 走看看