libstdc++,libstdc++.6.0.9缺失适配Xcode10与iOS12

编译报错

报错信息.png

开心得升级完新 macOS,以及新 XCode,准备体验了一把 Dark Mode 编程模式,开心的打开自己的老项目的时候,发现编译不通过了,报错,


发现缺失爆红.png

工程中如果依赖 libstdc++,无论是你本身的功能用 C++ 跨平台编写,还是你引入了某个 SDK 其内部依赖这个 libstdc++,都会导致整个工程编译不通过,报出 Undefined symbols,C++ 的 List 找不到了,
原因是苹果在 XCode10 和 iOS12 中移除了 libstdc++ 这个库,由 libc++ 这个库取而代之,苹果的解释是 libstdc++ 已经标记为废弃有5年了,建议大家使用经过了 llvm 优化过并且全面支持C++11的 libc++ 库。

临时解决办法

  • 编译问题
    拷贝缺失的libstdc++
    在 XCode10 正式发布前,XCode10 目前是 Beta 版,和 XCode9 正式版可以共存
    于是从 XCode9 的目录里,把缺失的 .tbd 文件拷贝过来,要记得拷贝2套,一套是模拟器的,一套是设备的,可以简单的用下面的命令
cp /Applications/Xcode.app/Contents/Developer/Platforms/iPhoneOS.platform/Developer/SDKs/iPhoneOS.sdk/usr/lib/libstdc++.* /Applications/Xcode-beta.app/Contents/Developer/Platforms/iPhoneOS.platform/Developer/SDKs/iPhoneOS.sdk/usr/lib/

cp /Applications/Xcode.app/Contents/Developer/Platforms/iPhoneSimulator.platform/Developer/SDKs/iPhoneSimulator.sdk/usr/lib/libstdc++.* /Applications/Xcode-beta.app/Contents/Developer/Platforms/iPhoneSimulator.platform/Developer/SDKs/iPhoneSimulator.sdk/usr/lib/

现在 XCode10 正式发布了,很多人已经没有 XCode9 来拷贝了,于是这里放出来文件提供下载

libstdc++.6.0.9.tbd.zip 解压,放到目录

/Applications/Xcode.app/Contents/Developer/Platforms/iPhoneOS.platform/Developer/SDKs/iPhoneOS.sdk/usr/lib/

查看是否存在.png

拷贝过去后,你就可以在新 XCode(黑暗模式真心舒服)下面看到libstdc++了,放心的添加到工程里吧

  • 模拟器运行
    image.png

    拷贝libstdc++之后就可以编译通过了,但 App 在模拟器里一运行就崩溃,就会报动态链接库装载出错,看出错提示说是 .dylib 与这个模拟器不符合。这是 XCode10 自带的 iOS12 模拟器的问题,在 XCode10 中安装 iOS11 的模拟器运行环境,然后切换到 iOS11 模拟器运行,一切问题没有。如果想在 XCode12 iOS12 模拟器中运行:
  1. libstdc++_sim.zip 解压,放到目录
/Applications/Xcode.app/Contents/Developer/Platforms/iPhoneSimulator.platform/Developer/SDKs/iPhoneSimulator.sdk/usr/lib/

  1. libstdc++.dylib_sim.zip 解压,放到目录
/Applications/Xcode.app/Contents/Developer/Platforms/iPhoneOS.platform/Developer/Library/CoreSimulator/Profiles/Runtimes/iOS.simruntime/Contents/Resources/RuntimeRoot/usr/lib/

  • 真机运行
    拷贝 libstdc++ 之后,使用 iOS12 的真机运行,没有啥太大的问题

正确解决办法

  • 如果你自己的业务模块使用了 libstdc++ ,那么就把模块代码重新调整为依赖 libc++ ,然后重新检查是否存在问题,重新编译
  • 如果你引用的三方库使用了 libstdc++ ,那么向三方库寻求支持,进行升级

libc++

Apple 为什么在 Mavericks 里把 C++ 标准库从 libstdc++ 改成 libc++?

关于此问题的讨论

Xcode10和iOS12踩坑

ps : 参考

折腾范儿の味精

libstdc++适配Xcode10与iOS12

推荐阅读更多精彩内容

  • 编译报错 开开心心的升级完新 macOS,以及新 XCode,准备体验了一把 Dark Mode 编程暗黑模式,快...
    iCoders阅读 6,496评论 7 17
  • 一、 libstdc++ 库项目用到了c++,依赖了libstdc++.tbd和libstdc++.6.0.9.t...
    执着攀攀阅读 2,823评论 1 9
  • 原文Xcode10和iOS12适配Xcode10和iOS12适配(持续更新)适配iPhoneX全系详解,更新Xco...
    00after阅读 1,153评论 0 6
  • 今天升级了xcode10 发现以前的老项目全部报错了,慌得一批!!! 赶紧想办法解决: 原来是苹果在XCode10...
    GuessYe阅读 201评论 0 2
  • iOS12的发布,带来了老设备性能提升,增强稳定性,更多是为了稳住果粉,更多是挽回被bugOS11坑苦的名声。为了...
    沈悦阅读 926评论 0 1