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/
|