我对共享库在Linux上的工作方式不了解。我试图了解应用程序如何在Linux上运行时解析同一共享库的不同修订版。
据我了解,共享库具有三个“名称”,例如,
通过LDCONFIG安装库时,它将创建以下符号链接
现在让我们说我用以下实名libmy.so.2.0编译同一库的另一个版本。根据指南,SONAME将为libmy.so.2.0
在应用程序链接时,我将使用“ -l”标志提供的链接器名称是什么。遵循我阅读的指南(http://www.dwheeler.com/program- library/Program-Library-HOWTO/x36.htm l),它不是必须是libmy.so,如果是的话,两个版本的版本如何obj文件的区别?
共享库的版本控制如下:
创建共享库时,请给它一个真实名称和一个soname。这些用于安装共享库(创建共享库和指向共享库的链接)。
soname
因此,您可能会遇到以下情况:
pax> ls -al xyz* -rw-r--r-- 1 pax paxgroup 12345 Nov 18 2009 xyz.so.1.5 lrwxrwxrwx 1 pax paxgroup 0 Nov 18 2009 xyz.so.1 -> xyz.so.1.5 lrwxrwxrwx 1 pax paxgroup 0 Nov 18 2009 xyz.so -> xyz.so.1
与xyz.so.1.5拥有的SONAME的xyz.so.1。
xyz.so.1.5
SONAME
xyz.so.1
当连接环节xyz.so,它遵循的链接一路xyz.so.1.5和使用其SONAME的xyz.so.1存储的可执行文件。然后,当您 运行 该可执行文件时,它会尝试加载xyz.so.1指向某个特定文件xyz.so.1.N(不一定是1.5版)的文件。
xyz.so
xyz.so.1.N
因此,您可以安装xyz.so.1.6和更新xyz.so.1链接以指向该链接,而已经链接的可执行文件将使用该链接。
xyz.so.1.6
这种多层方法的一个优点是,您可以拥有多个同名(xyz.so.1.*,xyz.so.2.*)的潜在不兼容库,但是在每个主要版本中, 由于它们应该兼容 ,因此可以自由升级它们。
xyz.so.1.*
xyz.so.2.*
链接新的可执行文件时:
xyz.so.1.2
现在,当我们检查您的评论时,请记住最后一段:
现在让我们说我用以下实名编译同一库的另一个版本libmy.so.2.0。根据指南,SONAME为libmy.so.2.0。
libmy.so.2.0
不,我不相信。该soname会更可能是libmy.so.2这样,你可以做轻微的更新到2.x流并获得最新的行为。
libmy.so.2
2.x