20

阅读苹果 SDK 指南 https://developer.apple.com/library/mac/#documentation/developertools/conceptual/cross_development/Overview/overview.html

我仍然对如何使 mac 应用程序向后兼容以及如何正确测试它们感到困惑

我有一个应用程序,我在 Mountain Lion 10.8 上运行并测试它没有任何问题,但是我想让这个应用程序向后兼容,以便其他用户可以在 mac 10.6 - 10.7 机器上运行它。

  1. 我有一个苹果开发者 ID,我可以下载 10.7 和 10.6 的旧版本,但问题是,我有一台 2011 版的 macbook air,目前运行的是 10.8,这是我唯一的苹果机。我可以使用 vmware 或 parallels 测试 10.7 和 10.6 吗?

  2. 在我的项目设置中,我将目标部署设置为 10.6(因为我希望 10.6 用户运行我的应用程序),但我应该将我的 SDK 设置为 10.8 还是 10.7?如果我将 SDK 设置为 10.8,但将目标部署设置为 10.6,如​​果我修复了所有 xcode 警告,它会在 10.6 上成功运行吗?

  3. 从 SDK 下拉菜单中,我只能设置为 10.8 或 10.7,但缺少 10.6,我该如何解决?

提前致谢

4

4 回答 4

45

我在 10.8 机器上开发并支持回到 10.5。就在几个月前,我们放弃了 10.4 PPC 支持,而我仍在清理一些 10.2 特定的代码。这可能会有点咆哮,但我已经做了很长时间的旧版本。我对此事有一些看法。

  • 不管 Apple 在他们的文档中说什么,如果您想支持 10.6,那么请使用 10.6 SDK 构建。不要依赖分布目标。
    • 我与 Xcode 工程师进行了讨论,虽然他们坚持 Apple 的党派路线,即您应该始终使用最新的 SDK 构建,但他们也承认这样做通常是疯狂的。如果您针对 10.8 SDK 构建并将您的部署目标标记为 10.6,您将不会收到使用 10.6 上不存在的方法的警告。你会发现你使用了一个不存在的方法的唯一方法是它在 10.6 上运行时可能会给你带来奇怪的错误。这太疯狂了。
    • 请记住,当您发送未知选择器时,OS X 不会崩溃。它只是中止当前的运行循环。因此,这些漏洞比在 iOS 上更难追踪,导致应用程序崩溃。
    • 当然,你可以做弱链接。谈论危险......是的,有几次这很有用,但如果你没有正确执行,编译器不会给你警告。如果我要像这样进行弱链接,我会采用另一种方式,链接旧 SDK 并将新函数的原型复制到我的实现中。这样我就有了我认为我要弱链接的每个函数的文档。
  • 下载旧的 SDK 并将它们符号链接到您的 Xcode 发行版中。
    • 嫉妒地保护他们。每次升级 Xcode 时,Apple 都会尝试删除它们。制作自己的副本并将它们粘贴到 /SDK 或远离 Xcode 的其他地方。我提供了一个名为fix-xcode的脚本来自动管理符号链接。我对 Apple 坚持删除我的旧 SDK 感到不满吗?我是。
  • 您可以合法地在 VM 中运行 10.6 Server。您可以合法地在 VM 中运行 10.7+ 桌面。这些是测试代码的好方法。
    • 或者你可以像我一样,拥有一小堆旧的 MacBook,每台都有两到三个分区,你一直在重启。
    • 现在 10.7 来自 App Store,制作 VM 有点困难。我强烈建议您在安装后立即对您的映像进行快照,并对其进行干净的备份。当您需要回到“原始”机器时,您会希望能够不时克隆该图像。
    • 养成在 SDK 发布时将其保存的习惯。10.8 总有一天会过时。您不妨现在就制作一份副本,这很容易。
  • 无论您是否支持单独的 dot 版本,保留各个 dot 版本的升级包都会非常有帮助。当您遇到运行非当前版本的客户时,很高兴能够检查“不可重现”的错误实际上是否可以在他们的特定版本上轻松重现。这是否值得在很大程度上取决于您的产品和客户。当 10.4.11 在 dot 发布期间对 WebKit 进行重大更改时,这对我来说是一个救命稻草……
  • 投资一个小型 NAS 或一个大型外部 USB 驱动器(尽管我在广泛使用时遇到了失败的问题,所以我更喜欢 RAID)。你需要空间。你想要持有大量的虚拟机和大量的 SDK,有时甚至是旧版本的 Xcode。
于 2013-02-26T15:20:04.717 回答
2

添加到 Rob Napier 的深入回答

要使用旧的 SDK,请将 SDK(或符号链接)放在这里:

/Applications/Xcode.app/Contents/Developer/Platforms/MacOSX.platform/Developer/SDKs

使用 XCode 7.3 或更高版本,您需要打开此文件并更改“MinimumSDKVersion”(否则 XCode 将拒绝使用旧 SDK):

/Applications/Xcode.app/Contents/Developer/Platforms/MacOSX.platform/Info.plist
于 2016-05-09T09:23:39.143 回答
1
  1. 您可以在一台机器上安装多个版本的 Mac OS,并在每个版本之间启动。
  2. SDK 应该是最新的 (10.8)。
  3. 见 2。

我考虑过的一种替代方法(我在同一条船上)是使用旧 PC 创建一个 Snow Leopard Hackintosh,然后在我的 MBP 上安装 Lion 和 Mountain Lion。

于 2013-02-26T14:07:22.987 回答
0

您需要进行以下设置:

1.将 Base SDK 设置为 Mac 的当前版本(例如 10.7)

2.将部署SDK设置为旧版本(ex.1.4)

于 2013-02-26T14:06:36.617 回答