• Linux下动态链接库和静态链接库


    最近又重新复习了一下Linux下动态链接库和静态链接库,稍作笔记以备后查。

    1. 静态链接库和动态链接库

     静态链接库就是一个多个汇编文件(obj文件)的集合,在Linux中通常命名为libxxx.a。对于静态链接库函数的连接是在编译阶段,直接将obj文件的一份拷贝代码连接到目标文件。

      动态链接库也是一个或多个汇编文件的集合,在Linux中通常命名为libxxx.so。对于动态链接库函数的链接是在运行阶段,各个目标程序之间共享同一份库文件。在编译阶段仅仅加载了函数符号。

      优缺点:

     1. 静态库的优点

      在编译阶段就完成连接,不需要单独库文件。(简单、直接、粗暴)。

     2. 静态链接库的缺点

      1) 由于每个目标程序都需要拷贝一份连接代码,所以会加重内存的负载。

      2) 即使目标程序在运行过程中调用不到链接库的函数(比如分支程序),静态库也需要加载。

     3. 动态库的优点:

      1) 代码共享,当多个程序运行同一个动态库的时候,其实他们是共享的同一份代码。减少了内存的使用量。

      2)按需加载,只有当运行过程中需要使用动态库的函数,才会去加载动态库。减少了不必要的内存消耗。

     4. 动态库的缺点:

      1) 由于是在运行阶段,才进行加载,所有会降低目标代码的执行速度。

    需要注意一点:

      由于代码共享,所以动态库在编译的时候,内部需要使用相对地址。

    2. 静态库的创建和使用

      两步走,step1 生成编译后的文件,利用ar命令进行打包

      gcc -c test.c

      ar cr ar cr libtest.a test1.o

    3. 动态库的创建

      动态库在创建的时候必须注意一点

      gcc -fPIC -c test.c

      gcc -shared libtest.so test.o  

      使用方法一

      gcc -o main main.c 库文件全路径

      使用方法二

      gcc -o main -Lpath -Ixxx -lxxx

      -L:后面直接跟路径名

      -I:头文件的路径

      -l:xxx会寻找libxxx.so文件

  • 相关阅读:
    详解softmax函数以及相关求导过程 (转载自知乎)
    每日算法
    每日算法
    每日算法
    每日算法
    每日算法
    广度优先搜索算法
    java实现fp-growth算法
    频繁项集挖掘之Aprior和FPGrowth算法
    频繁项集挖掘之apriori和fp-growth
  • 原文地址:https://www.cnblogs.com/codingrabbit/p/5251544.html
Copyright © 2020-2023  润新知