OStack程序员社区-中国程序员成长平台

标题: c++ - OSX 中动态链接优先级之间的冲突? [打印本页]

作者: 菜鸟教程小白    时间: 2022-8-3 00:18
标题: c++ - OSX 中动态链接优先级之间的冲突?

OSX 上不同的 libjpeg 动态库之间存在动态链接冲突。首先有一个标准的原生 libJPEG.dylib(在/System/Library/Frameworks/ImageIO.framework/Versions/A/Resources/)。但是如果你使用的是 MacPorts,你也可以在(/opt/local/lib)中有一个与端口相关的 libjpeg.dylib。例如,后者可能已作为某个其他端口的依赖项安装。

当您链接到系统 libJPEG(首选)时,这会产生问题。
那么如果 /opt/local/lib在 DYLD_LIBRARY_PATH 中,搜索动态库时将优先考虑该路径,导致加载符号时出现运行时错误:

dyld: Symbol not found: __cg_jpeg_resync_to_restart
 Referenced from:
/System/Library/Frameworks/ImageIO.framework/Versions/A/ImageIO
 Expected in: /opt/local/lib/libJPEG.dylib
in /System/Library/Frameworks/ImageIO.framework/Versions/A/ImageIO
Trace/BPT trap: 5

所以我有两个问题(可能相关):
  • 什么是解决实际问题的好方法(从 /opt/local/lib 中删除 DYLD_LIBRARY_PATH 显然可以解决它,但会为其他依赖项带来问题)?
  • 搜索动态库的其他路径(即指定的“/System/Library”路径在哪里)以及为什么 DYLD_LIBRARY_PATH 优先级更高?


  • Best Answer-推荐答案


    我在 MacOS El Capitan 中使用 OpenCV 时遇到了类似的问题。使用link中的解决方案解决了问题

    解决办法是删除/usr/local/lib目录下的一些dlylibs,并创建相关文件的符号链接(symbolic link)/System/Library/Frameworks/ImageIO.framework/Resources/

    cd /usr/local/lib
    rm libgif.dylib
    ln -s /System/Library/Frameworks/ImageIO.framework/Resources/libGIF.dylib libGIF.dylib
    rm libjpeg.dylib
    ln -s /System/Library/Frameworks/ImageIO.framework/Resources/libJPEG.dylib libJPEG.dylib
    rm libtiff.dylib
    ln -s /System/Library/Frameworks/ImageIO.framework/Resources/libTIFF.dylib libTIFF.dylib
    rm libpng.dylib
    ln -s /System/Library/Frameworks/ImageIO.framework/Resources/libPng.dylib libPng.dylib
    

    关于c++ - OSX 中动态链接优先级之间的冲突?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/17643509/






    欢迎光临 OStack程序员社区-中国程序员成长平台 (https://ostack.cn/) Powered by Discuz! X3.4