静态链接与动态链接的区别

     我们大家在编程过程中对“链接”这个词并不陌生,链接所解决的问题即是将我们自己写的代码和别人写的库集成在一起。链接可以分为静态链接与动态链接,下文将分别讲解这两种方式的特点与其区别。
  1. 静态链接
    • 特点在生成可执行文件的时候(链接阶段),把所有需要的函数的二进制代码都包含到可执行文件中去。因此,链接器需要知道参与链接的目标文件需要哪些函数,同时也要知道每个目标文件都能提供什么函数,这样链接器才能知道是不是每个目标文件所需要的函数都能正确地链接。如果某个目标文件需要的函数在参与链接的目标文件中找不到的话,链接器就报错了。目标文件中有两个重要的接口来提供这些信息:一个是符号表,另外一个是重定位表
    • 优点:在程序发布的时候就不需要的依赖,也就是不再需要带着库一块发布,程序可以独立执行。
    • 缺点:
      1. 程序体积会相对大一些。
      2. 如果静态库有更新的话,所有可执行文件都得重新链接才能用上新的静态库。
  2. 动态链接
    • 特点: 在编译的时候不直接拷贝可执行代码,而是通过记录一系列符号和参数,在程序运行或加载时将这些信息传递给操作系统,操作系统负责将需要的动态库加载到内存中,然后程序在运行到指定的代码时,去共享执行内存中已经加载的动态库可执行代码,最终达到运行时连接的目的。
    • 优点: 多个程序可以共享同一段代码,而不需要在磁盘上存储多个拷贝。
    • 缺点: 由于是运行时加载,可能会影响程序的前期执行性能。
          上面的文章多次提到库(lib)这个概念,所谓的库 是一些功能代码经过编译连接后的可执行形式。
             大家在Windows平台上见到的.dll文件和linux平台下so动态库都输入库。
             库也有静态lib和动态lib之分:
      1. 静态lib将导出声明和实现都放在lib中。编译后所有代码都嵌入到宿主程序。
      2. 动态lib相当于一个h文件,是对实现部分(.dll文件)的导出部分的声明。编译后只是将导出声明部分编译到宿主程序中,运行时候需要相应的dll文件支持。

你可能感兴趣的:(链接,编译,动态链接,静态链接)