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.
For TypedData (e.g. ByteBuffer, Uint8List) the exteremely fast xxh3 algorithm is used.
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.
Running benchmark on list of strings...
equatable for 1000000 elements(RunTime): 3727783.0 us.
fast_equatable (mutable) for 1000000 elements(RunTime): 3697050.5 us.
fast_equatable (immutable) for 1000000 elements(RunTime): 988318.0 us.
Running benchmark on raw data...
equatable for 10000 elements(RunTime): 3628557.5 us.
fast_equatable (mutable) for 10000 elements(RunTime): 2020746.0 us.
fast_equatable (immutable) for 10000 elements(RunTime): 3004.28035982009 us.
Libraries
- fast_equatable
- hash
- Exports the secureHashfunction