Thanks.

What about the perf of something like this...

({{:x 1 :y 2} :point} {:x 1 :y 2})

vs

({1 2} 1)

and what if the map was mutable as a key?

On Saturday, June 27, 2015 at 10:08:19 AM UTC-4, Andy Fingerhut wrote:
>
> (let [foo {:x 1}]
>   (= foo foo))
>
> is fast, because they are identical, and = is fast for things that are 
> identical.
>
> In general, two maps that are = are often not identical.
>
> If two maps have different numbers of elements, = should quickly return 
> false because of the way equiv() is implemented for maps, here: 
> https://github.com/clojure/clojure/blob/master/src/jvm/clojure/lang/APersistentMap.java#L73-L94
>
> There is a check whether the maps are the same size, and if not, return 
> false without checking all key/value pairs.
>
> If they have equal number of key/value pairs, then it will iterate through 
> all key/value pairs of one, checking whether the key of one is present in 
> the other, and if so, whether their associated values are equiv() or not.
>
> Those checks can be fast if the keys are quickly comparable, and the 
> values are quickly comparable.
>
> If you take one persistent map m1 and remove a few keys and/or add a few 
> keys to produce m2, then all of the unchanged keys and values they have in 
> common will be identical, and very quickly comparable.  The slowest part of 
> comparing them would be comparing their non-identical parts.
>
> Andy
>
> On Sat, Jun 27, 2015 at 5:01 AM, Jacob Goodson <[email protected] 
> <javascript:>> wrote:
>
>> I was wondering something...
>>
>> Would (= {:x 1} {:x 1}) be just as fast as (= 1 1) since maps are 
>> immutable?  The idea is that since clojure data structures are just values 
>> can they be compared much faster than there mutable counter parts?  Thanks.
>>
>> -- 
>> You received this message because you are subscribed to the Google
>> Groups "Clojure" group.
>> To post to this group, send email to [email protected] 
>> <javascript:>
>> Note that posts from new members are moderated - please be patient with 
>> your first post.
>> To unsubscribe from this group, send email to
>> [email protected] <javascript:>
>> For more options, visit this group at
>> http://groups.google.com/group/clojure?hl=en
>> --- 
>> You received this message because you are subscribed to the Google Groups 
>> "Clojure" group.
>> To unsubscribe from this group and stop receiving emails from it, send an 
>> email to [email protected] <javascript:>.
>> For more options, visit https://groups.google.com/d/optout.
>>
>
>

-- 
You received this message because you are subscribed to the Google
Groups "Clojure" group.
To post to this group, send email to [email protected]
Note that posts from new members are moderated - please be patient with your 
first post.
To unsubscribe from this group, send email to
[email protected]
For more options, visit this group at
http://groups.google.com/group/clojure?hl=en
--- 
You received this message because you are subscribed to the Google Groups 
"Clojure" group.
To unsubscribe from this group and stop receiving emails from it, send an email 
to [email protected].
For more options, visit https://groups.google.com/d/optout.

Reply via email to