【发布时间】:2013-07-12 16:25:04
【问题描述】:
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
所以我有两个问题(可能相关):
什么是解决实际问题的好方法(从
DYLD_LIBRARY_PATH中删除/opt/local/lib显然可以解决它,但会给其他依赖项带来问题)?搜索动态库的其他路径(即“/System/Library”路径在哪里指定)以及为什么 DYLD_LIBRARY_PATH 的优先级更高?
【问题讨论】: