contains 方法

bool contains(
  1. Object? element
)
override

判断集合是否包含与 element 相等的元素。

此操作将按顺序检查每个元素是否等于 element,除非有更有效的方法来查找与 element 相等的元素。在找到第一个相等的元素时停止迭代。

用于判断 element 是否等于可迭代元素中的元素的相等性,默认为元素的 Object.==

某些类型的可迭代可能使用与其元素不同的相等性。例如,一个 Set 可能有一个自定义的相等性(见 Set.identity),其 contains 方法将使用。同样,Map.keys 调用返回的 Iterable 应使用与 Map 为键使用的相同的相等性。

示例

final gasPlanets = <int, String>{1: 'Jupiter', 2: 'Saturn'};
final containsOne = gasPlanets.keys.contains(1); // true
final containsFive = gasPlanets.keys.contains(5); // false
final containsJupiter = gasPlanets.values.contains('Jupiter'); // true
final containsMercury = gasPlanets.values.contains('Mercury'); // false

实现

bool contains(Object? element) {
  int length = this.length;
  for (int i = 0; i < length; i++) {
    if (this[i] == element) return true;
    if (length != this.length) {
      throw ConcurrentModificationError(this);
    }
  }
  return false;
}