1

Node 是一个泛型类型。

struct Node<T: Hashable>: Hashable {
    var label: T

    init(_ label: T) {
        self.label = label
    }

    var hashValue : Int {
        get {
            return label.hashValue
        }
    }
}

extension Node : Equatable {}

// MARK: Equatable

func ==<T>(lhs: Node<T>, rhs: Node<T>) -> Bool {
    return lhs.label == rhs.label
}

但是当我尝试以下操作时它不起作用:

let nodes = Set<Node<String>>()

编译器抱怨Node<String>不符合 Hashable。如何使Node<String>符合 Hashable?

4

1 回答 1

2

您还必须将该==方法作为Equatable结构协议的一部分来实现:

func ==<T, K>(lhs:Node<T>, rhs:Node<K>) -> Bool {
    return lhs.hashValue == rhs.hashValue
}

原因是Hashable继承自Equatable.

以下是一个完整的工作游乐场示例:

struct Node<T: Hashable> : Hashable {
    var label: T

    init(_ label: T) {
        self.label = label
    }

    var hashValue : Int {
        get {
            return label.hashValue
        }
    }
}

func ==<T>(lhs:Node<T>, rhs:Node<T>) -> Bool {
    return lhs.hashValue == rhs.hashValue
}

var nodes = Set<Node<String>>()
nodes.insert(Node("hi"))
nodes.insert(Node("ho"))
nodes.insert(Node("hi"))
于 2016-01-22T13:21:23.657 回答