Overview

This is a simple Dart package that provides fast and secure equality comparison as a mixin. This provides great compatibility to exsiting code.

It optionally offers hash caching to improve the speed of e.g. Map's and Set's significantly.

By default the widely spread Jenkins hash function is used, but you are free to also implement and provide your own hash engine, suiting your needs.

Objects of any kind are allowed into hashParameters. Simple types and the standard collections like List, Iterable, Map an Set are supported by default. When you use own classes make sure to use the FastEquatable mixin as well, or make sure at least hashCode and operator == are overriden.

Example

class FastEquatableCached with FastEquatable {
  final String value1;
  final List<String>? value2;

  FastEquatableCached(this.value1, this.value2);

  @override
  //This is a immutable object, so we want to cache the hash
  bool get cacheHash => true;

  @override
  List<Object?> get hashParameters => [value1, value2];
}

Benchmark

In the example you will find a benchmark code, showing off the resulting speed improvement.

equatable for 1000000 elements(RunTime): 8583044.5 us.
fast_equatable (uncached) for 1000000 elements(RunTime): 8493327.5 us.
fast_equatable (cached) for 1000000 elements(RunTime): 3329455.5 us.

Libraries

fast_equatable