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 的优先级更高?