一尘不染

为什么我应该只为更新库而重新编译整个程序?

linux

关于以下链接:http : //www.archlinux.org/news/libpnglibtiff-rebuilds-move-from-
testing/

有人可以向我解释为什么其中一个库已更新后应重新构建程序吗?

既然根本没有更改“主”文件,那有什么意义?


阅读 271

收藏
2020-06-07

共1个答案

一尘不染

如果所涉及功能的签名没有更改,则“重建”程序意味着必须再次 链接 目标文件。您无需再次 编译 它们。

API是合约,描述了库中公共功能的接口。当编译器生成代码时,它需要知道什么类型的变量以及以什么顺序传递给每个函数。它还需要知道返回类型,因此它知道将从函数返回的数据的大小和格式。编译代码时,库函数的地址可能表示为“库的开头加上140字节”。编译器不知道绝对地址,因此仅指定距库开头的偏移量。

但是 库中,功能的 内容
(即实现)可能会更改。发生这种情况时,代码的长度可能会更改,因此函数的地址可能会更改。链接器的工作是了解每个函数的入口点所在的位置,并将这些地址填充到目标代码中以创建可执行文件。

另一方面,如果库中的 数据结构 发生了变化,并且库要求调用者管理内存(这是一种不好的做法,但不幸的是很常见),那么您
需要重新编译代码,以便它可以解决这些更改。例如,如果您的代码用于malloc(sizeof(dataStructure))为大小加倍的库数据结构分配内存,则您将需要重新编译代码,因为sizeof(dataStructure)它将具有更大的值。

2020-06-07