Proposed rename of Map.forEach(BiBlock<? super K, ? super V> block)
Doug Lea
dl at cs.oswego.edu
Wed Dec 26 06:16:00 PST 2012
On 12/26/12 09:08, Remi Forax wrote:
> On 12/26/2012 04:34 AM, Raab, Donald wrote:
>> Can we rename the forEach(BiBlock<? super K, ? super V> block) method to
>> forEachKeyValue(BiBlock<? super K, ? super V> block) on Map please?
>
> yes,
> there are 3 different forEach on Iterator, Iterable and Map, an already existing
> code that mixes two of them, by example a Map that is an iterator too,
> will not compile with Java 8.
For this and other reasons, we decided when adding other default
methods to map last week or so, to omit this method entirely, so
it isn't in the current lambda repo.
-Doug
>
> Rémi
>
>>
>> In GS Collections, our MapIterable<K, V> interace extends RichIterable<V>
>> which extends Iterable<V>. This is a choice which makes it consistent with
>> Smalltalk. This results in us having a method forEach(Procedure<? super V>)
>> defined on all our Map implementations. This will also cause us to have a
>> method forEach(Block<? super V> block) defined when JDK 8 is released. Having
>> a third overloaded forEach() method will cause a lot of confusion for us.
>>
>> https://github.com/goldmansachs/gs-collections/blob/master/collections-api/src/main/java/com/gs/collections/api/map/MapIterable.java#L33
>>
>>
>> Hopefully there are no plans to have Map re-defined as Map<K, V> extends
>> Iterable<Entry<K, V>> in JDK 8. Otherwise this would result in forEach()
>> having to be redefined as forEach<Map.Entry<K, V>>.
>>
>> For future reference, Trove defines these methods in THashMap:
>>
>> forEachKey(TObjectProcedure<? super K> procedure)
>> forEachValue(TObjectProcedure<? super V> procedure)
>> forEachEntry(TObjectObjectProcedure<? super K,? super V> procedure)
>>
>> GS Collections defines these methods in MapIterable:
>>
>> forEach(Procedure<? super V> procedure) // extended from RichIterable<V> which
>> ultimately extends Iterable<V>
>> forEachKey(Procedure<? super K> procedure)
>> forEachValue(Procedure<? super V> procedure)
>> forEachKeyValue(Procedure2<? super K, ? super V> procedure)
>>
>> I would suggest adding the other two methods forEachKey(Block<? super K>) and
>> forEachValue(Block<? super V>) to Map for JDK 8 even though this will result
>> in more casting at call sites for users of Trove and GS Collections since our
>> methods will become overloads of the equivalent methods on Map. The current
>> recommended workaround as I understand it will be to have our function types
>> extend Block and BiBlock when JDK 8 is released.
>>
>>
>>
>
More information about the lambda-libs-spec-observers
mailing list