Skip to content

Commit

Permalink
== docs: strengthen link between hashing and equality (JuliaLang#55135)
Browse files Browse the repository at this point in the history
  • Loading branch information
mbauman authored and lazarusA committed Aug 17, 2024
1 parent 61fc3f4 commit fd1aca3
Showing 1 changed file with 4 additions and 3 deletions.
7 changes: 4 additions & 3 deletions base/operators.jl
Original file line number Diff line number Diff line change
Expand Up @@ -111,9 +111,10 @@ Use [`isequal`](@ref) or [`===`](@ref) to always get a `Bool` result.
New numeric types should implement this function for two arguments of the new type, and
handle comparison to other types via promotion rules where possible.
[`isequal`](@ref) falls back to `==`, so new methods of `==` will be used by the
[`Dict`](@ref) type to compare keys. If your type will be used as a dictionary key, it
should therefore also implement [`hash`](@ref).
Equality and hashing are intimately related; two values that are considered [`isequal`](@ref) **must**
have the same [`hash`](@ref) and by default `isequal` falls back to `==`. If a type customizes the behavior of `==` and/or [`isequal`](@ref),
then [`hash`](@ref) must be similarly implemented to ensure `isequal` and `hash` agree. `Set`s, `Dict`s, and many other internal
implementations assume that this invariant holds.
If some type defines `==`, [`isequal`](@ref), and [`isless`](@ref) then it should
also implement [`<`](@ref) to ensure consistency of comparisons.
Expand Down

0 comments on commit fd1aca3

Please sign in to comment.