作为 NS_OPTIONS 迁移至 GMSPlaceField

从 Places SDK for iOS 4.0.0 版开始,GMSPlaceField 类型现在使用 NS_OPTIONS 宏。SDK 的 3.x 版本将 GMSPlaceField 用作 NS_ENUM,并且仍受支持。

  • 如果您使用的是 Objective-C:没有任何影响。您可以继续像以前一样使用 GMSPlaceField

  • 如果您使用的是 Swift:如果您使用 GMSPlaceField(rawValue:) 语法作为构造函数(旧版 SDK 将其作为可选的 GMSPlaceField? 返回),您的实现将会中断。版本 4.0.0 及更高版本会返回非可选的 GMSPlaceField 值;对可选项执行的任何操作(例如条件检查或强制展开)都将失败。此外,您现在可以使用数组语法组合 GMSPlaceField

迁移代码

某些条件解封或强制解封语法在 Swift 中会破坏。以下示例展示了如何解决这些问题,还演示了如何使用数组语法声明 GMSPlaceField

有条件的取消封装

以下示例中的语句展示了使用 if 创建需要条件解封的 GMSPlaceField 数组。这将导致编译器错误(“条件绑定的初始化程序必须是可选类型,而不是 GMSPlaceField”)。

// Before.
if let field = GMSPlaceField(
    rawValue: GMSPlaceField.name.rawValue | GMSPlaceField.photos.rawValue
) { // Do something }

如需解决此问题,请移除 if 语句,如下所示:

// After.
let field =  GMSPlaceField(
    rawValue: GMSPlaceField.name.rawValue | GMSPlaceField.photos.rawValue
)
// Do something

您还可以使用数组语法,如下所示:

let field = [GMSPlaceField.name, GMSPlaceField.photos]
// or
let field: GMSPlaceField = [.name, .photos]

强制取消封装

以下示例中的语句展示了如何将 GMSPlaceField 用作非可选类型。这将导致编译器错误(“无法强制取消封装非可选类型 GMSPlaceField 的值”):

// Before.
let field = GMSPlaceField(
    rawValue: GMSPlaceField.name.rawValue | GMSPlaceField.photos.rawValue
)!

如需解决此问题,请将 GMSPlaceField 用作可选类型,如下所示:

// After.
let field =  GMSPlaceField(
    rawValue: GMSPlaceField.name.rawValue | GMSPlaceField.photos.rawValue
)

您还可以使用数组语法,如下所示:

let field = [GMSPlaceField.name, GMSPlaceField.photos]
// or
let field: GMSPlaceField = [.name, .photos]