有人可以给我一个为什么它不起作用的充分理由:
let a: [Int]? = [1]
let b: [Int]? = nil
a == b
这将是我建议的(如果不太出色)的解决方案。但这是微不足道的,所以我觉得我很想知道为什么未实现这一点的充分理由。
func ==<T: Equatable>(lhs: [T]?, rhs: [T]?) -> Bool {
if let lhs = lhs, let rhs = rhs {
return lhs == rhs
}
else if let _ = lhs {
return false
}
else if let _ = rhs {
return false
}
return true
}
更新: 条件一致性已在 Swift 4.1中 实现 。 数组和Equatable
元素的可选元素本身就是
Equatable
现在,您的代码
let a: [Int]? = [1]
let b: [Int]? = nil
a == b
可以按照Xcode 9.3的要求进行编译和工作。不再需要解决方法。
(旧答案:) 仅当基础包装类型为等值类型时,才可以比较可选选项:
public func ==<T : Equatable>(lhs: T?, rhs: T?) -> Bool
现在,如果元素类型是相等的,则可以 比较 数组:
/// Returns true if these arrays contain the same elements.
public func ==<Element : Equatable>(lhs: [Element], rhs: [Element]) -> Bool
但即使equatable类型T
, Array<T>
不符合 该Equatable
协议。
目前,这在Swift中是不可能的,例如参见
为什么我不能使Array符合Equatable?在Apple开发者论坛上进行讨论。
在Swift 4中通过SE-0143条件一致性的实现进行了此更改。
您的实现看起来是正确的,这是使用带有模式匹配的开关/案例的可能不同的方法:
func ==<T: Equatable>(lhs: [T]?, rhs: [T]?) -> Bool {
switch (lhs, rhs) {
case let (l?, r?) : // shortcut for (.Some(l), .Some(r))
return l == r
case (.None, .None):
return true
default:
return false
}
}
本文向大家介绍自定义组件时render是可选的吗?为什么?相关面试题,主要包含被问及自定义组件时render是可选的吗?为什么?时的应答技巧和注意事项,需要的朋友参考一下 根据文档描述,class组件的render函数是必选的:The render() method is the only required method in a class component. 对应文档: https://re
问题内容: 我正在使用Vue.js创建一个组件。 当我引用中的任何所述的生命周期钩(,,等等)它的计算结果为: 我的计算属性内部也发生了同样的事情: 我收到以下错误: 未捕获的TypeError:无法读取未定义的属性“ bar” 为什么要在这些情况下进行评估? 问题答案: 这两个示例都使用arrow函数,该函数绑定到与Vue实例不同的上下文。 根据文档: 不要在实例属性或回调(例如)上使用箭头功能
问题内容: var x int done := false go func() { x = f(…); done = true } while done == false { } 这是Go代码。我的恶魔告诉我,这是UB代码。为什么? 问题答案: Go Memory Model不保证该程序将始终遵守在goroutine中写入x的值。go常规销毁 部分中提供了一个类似的错误程序作为示例。 在本节中,G
我找不到这个职位的申请书http://127.0.0.1:3001/users?name=Slava. 服务器响应“需要名称”。方法getUsers正常工作。数据库工作正常,服务器。js也能工作。我在这里寻找类似的答案,但没有合适的答案。有一些非常古老的答案,但它们并不相关。 这是一项请求:http://127.0.0.1:3001/users?name=bob (我用邮递员送信)
我在chrome控制台中写了这样的表达式: 它返回:
问题内容: 最近几天,我试图学习如何通过Java访问mySQL数据库。我能够加载驱动程序并获得与数据库的连接(至少我认为是这样,因为那里没有异常。) 代码是: 当我执行它时,它说: 驱动程序已加载… 连接成功… 数据库-ConnectionError:java.sql.SQLException:[MySQL] [ODBC 5.2(w)驱动程序] [mysqld-5.5.31]未选择数据库 我真的不