我正在尝试创建一个符合Comparable协议的简单通用节点类,以便我可以轻松地比较节点而无需访问其密钥.当我试图写<和==函数,但是,编译器似乎不喜欢它. <和==函数在定义Node参数时需要一个类型.这在Java中很简单,你定义了相等性和<在课堂内部.斯威夫特在全球范围内要求它.有什么想法吗 ? 例:
func < (lhs:Node<E:Comparable>,rhs:Node<E:Comparable>) -> Bool { return lhs.key < rhs.key } func == (lhs:Node<E:Comparable>,rhs:Node<E:Comparable>) -> Bool { return lhs.key == rhs.key } class Node<D:Comparable>: Comparable { var key: D! var next:Node? var prev:Node? init( key:D ) { self.key = key } }
你很亲密! Node类已经指定对于Node< D>,D必须符合Comparable.因此,Node< E:Comparable>在==和<的decl中是多余的.相反,您希望限制可以调用运算符的类型:
func < <E: Comparable>(lhs: Node<E>,rhs: Node<E>) -> Bool { return lhs.key < rhs.key } func == <E: Comparable>(lhs: Node<E>,rhs: Node<E>) -> Bool { return lhs.key == rhs.key } class Node<D: Comparable>: Comparable { var key: D! var next: Node? var prev: Node? init(key: D) { self.key = key } }