<div dir="ltr">It is generally a bad idea to rely on order in anything which uses a hash function. The hash function is often subject to change---rather quickly I might add if it proves to be a security bug. Picking a family of hashes and seeding it randomly is usually a good trick.<div><br></div><div>Our "sister language" Go *randomizes* iteration order on its maps. This is to force programmers into not relying on the map order at all, even if it happens to be ordered right now. This opens up implementations in the future.</div><div><br></div><div>If you wanted order in a map, it would be *far* better if you could create a map based on RB-trees or the like. Those are naturally ordered by structure. OCaml, for instance, defines Hash Tables as well as Maps. The latter is the ordered variant.</div><div><br></div></div><br><div class="gmail_quote"><div dir="ltr">On Thu, Oct 26, 2017 at 8:07 PM Ulf Wiger <<a href="mailto:ulf@wiger.net">ulf@wiger.net</a>> wrote:<br></div><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex"><div dir="auto"><div>But they *are* ordered. Otherwise, comparison of two maps would be undefined. </div><div dir="auto"><br></div><div dir="auto">BR, </div><div dir="auto">Ulf W</div></div><div dir="auto"><div dir="auto"><br><div class="gmail_extra" dir="auto"><br><div class="gmail_quote">Den 26 okt. 2017 18:20 skrev "Roger Lipscombe" <<a href="mailto:roger@differentpla.net" target="_blank">roger@differentpla.net</a>>:<br type="attribution"><blockquote class="m_-8746558959939451565quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex"><div class="m_-8746558959939451565quoted-text">On 26 October 2017 at 16:30, Ulf Wiger <<a href="mailto:ulf@wiger.net" target="_blank">ulf@wiger.net</a>> wrote:<br>
> Wouldn't it be reasonable to have such a function?<br>
<br>
</div>First thought: No, because people would start abusing it. Maps *aren't* ordered.<br>
</blockquote></div><br></div></div></div>
_______________________________________________<br>
erlang-questions mailing list<br>
<a href="mailto:erlang-questions@erlang.org" target="_blank">erlang-questions@erlang.org</a><br>
<a href="http://erlang.org/mailman/listinfo/erlang-questions" rel="noreferrer" target="_blank">http://erlang.org/mailman/listinfo/erlang-questions</a><br>
</blockquote></div>