changes
This commit is contained in:
parent
64b7dec1b0
commit
ece4d65065
|
@ -0,0 +1,42 @@
|
||||||
|
package com.baeldung.collections.mapfirstpair;
|
||||||
|
|
||||||
|
import java.util.Iterator;
|
||||||
|
import java.util.Map;
|
||||||
|
import java.util.Set;
|
||||||
|
|
||||||
|
public class MapFirstPairExample {
|
||||||
|
|
||||||
|
public Map.Entry<Integer, String> getFirstPairUsingIterator(Map<Integer, String> map) {
|
||||||
|
if (map == null || map.size() == 0)
|
||||||
|
return null;
|
||||||
|
|
||||||
|
Iterator<Map.Entry<Integer, String>> iterator = map.entrySet()
|
||||||
|
.iterator();
|
||||||
|
|
||||||
|
if (iterator.hasNext())
|
||||||
|
return iterator.next();
|
||||||
|
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
|
||||||
|
public Map.Entry<Integer, String> getFirstPairUsingStream(Map<Integer, String> map) {
|
||||||
|
if (map == null || map.size() == 0)
|
||||||
|
return null;
|
||||||
|
|
||||||
|
Set<Map.Entry<Integer, String>> entrySet = map.entrySet();
|
||||||
|
|
||||||
|
return entrySet.stream()
|
||||||
|
.findFirst()
|
||||||
|
.get();
|
||||||
|
}
|
||||||
|
|
||||||
|
public Map<Integer, String> populateMapValues(Map<Integer, String> map) {
|
||||||
|
if (map != null) {
|
||||||
|
map.put(5, "A");
|
||||||
|
map.put(1, "B");
|
||||||
|
map.put(2, "C");
|
||||||
|
}
|
||||||
|
return map;
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
|
@ -1,17 +0,0 @@
|
||||||
/**
|
|
||||||
*
|
|
||||||
*/
|
|
||||||
package com.baeldung.collections.mapfirstpair;
|
|
||||||
|
|
||||||
import java.util.Map;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @author ASHWINI
|
|
||||||
*
|
|
||||||
*/
|
|
||||||
public interface MapFirstPairService {
|
|
||||||
|
|
||||||
<K, V> Map.Entry<K, V> getFirstPairUsingIterator(Map<K, V> map);
|
|
||||||
|
|
||||||
<K, V> Map.Entry<K, V> getFirstPairUsingStream(Map<K, V> map);
|
|
||||||
}
|
|
|
@ -1,40 +0,0 @@
|
||||||
/**
|
|
||||||
*
|
|
||||||
*/
|
|
||||||
package com.baeldung.collections.mapfirstpair;
|
|
||||||
|
|
||||||
import java.util.Iterator;
|
|
||||||
import java.util.Map;
|
|
||||||
import java.util.Set;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @author ASHWINI
|
|
||||||
*
|
|
||||||
*/
|
|
||||||
public class MapFirstPairServiceImpl implements MapFirstPairService {
|
|
||||||
|
|
||||||
public <K, V> Map.Entry<K, V> getFirstPairUsingIterator(Map<K, V> map) {
|
|
||||||
if (map == null || map.size() == 0)
|
|
||||||
return null;
|
|
||||||
|
|
||||||
Iterator<Map.Entry<K, V>> iterator = map.entrySet()
|
|
||||||
.iterator();
|
|
||||||
|
|
||||||
if (iterator.hasNext())
|
|
||||||
return iterator.next();
|
|
||||||
|
|
||||||
return null;
|
|
||||||
}
|
|
||||||
|
|
||||||
public <K, V> Map.Entry<K, V> getFirstPairUsingStream(Map<K, V> map) {
|
|
||||||
if (map == null || map.size() == 0)
|
|
||||||
return null;
|
|
||||||
|
|
||||||
Set<Map.Entry<K, V>> entrySet = map.entrySet();
|
|
||||||
|
|
||||||
return entrySet.stream()
|
|
||||||
.findFirst()
|
|
||||||
.get();
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
|
|
@ -11,30 +11,22 @@ import java.util.Map;
|
||||||
import org.junit.Before;
|
import org.junit.Before;
|
||||||
import org.junit.Test;
|
import org.junit.Test;
|
||||||
|
|
||||||
public class MapFirstPairServiceUnitTest {
|
public class MapFirstPairUnitTest {
|
||||||
|
|
||||||
private MapFirstPairService mapFirstPairService;
|
private MapFirstPairExample mapFirstPairExample;
|
||||||
|
|
||||||
@Before
|
@Before
|
||||||
public void Setup() {
|
public void Setup() {
|
||||||
|
|
||||||
mapFirstPairService = new MapFirstPairServiceImpl();
|
mapFirstPairExample = new MapFirstPairExample();
|
||||||
}
|
|
||||||
|
|
||||||
private void populateMapValues(Map<Integer, String> map) {
|
|
||||||
if (map != null) {
|
|
||||||
map.put(5, "A");
|
|
||||||
map.put(1, "B");
|
|
||||||
map.put(2, "C");
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void whenUsingIteratorForHashMap() {
|
public void whenUsingIteratorForHashMap_thenFirstPairWhichWasNotInsertedFirst() {
|
||||||
Map<Integer, String> hashMap = new HashMap<>();
|
Map<Integer, String> hashMap = new HashMap<>();
|
||||||
populateMapValues(hashMap);
|
hashMap = mapFirstPairExample.populateMapValues(hashMap);
|
||||||
|
|
||||||
Map.Entry<Integer, String> actualValue = mapFirstPairService.getFirstPairUsingIterator(hashMap);
|
Map.Entry<Integer, String> actualValue = mapFirstPairExample.getFirstPairUsingIterator(hashMap);
|
||||||
Map.Entry<Integer, String> expectedValue = new AbstractMap.SimpleEntry<Integer, String>(1, "B");
|
Map.Entry<Integer, String> expectedValue = new AbstractMap.SimpleEntry<Integer, String>(1, "B");
|
||||||
Map.Entry<Integer, String> pairInsertedFirst = new AbstractMap.SimpleEntry<Integer, String>(5, "A");
|
Map.Entry<Integer, String> pairInsertedFirst = new AbstractMap.SimpleEntry<Integer, String>(5, "A");
|
||||||
|
|
||||||
|
@ -43,10 +35,10 @@ public class MapFirstPairServiceUnitTest {
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void whenUsingStreamForHashMap() {
|
public void whenUsingStreamForHashMap_thenFirstPairWhichWasNotInsertedFirst() {
|
||||||
Map<Integer, String> hashMap = new HashMap<>();
|
Map<Integer, String> hashMap = new HashMap<>();
|
||||||
populateMapValues(hashMap);
|
hashMap = mapFirstPairExample.populateMapValues(hashMap);
|
||||||
Map.Entry<Integer, String> actualValue = mapFirstPairService.getFirstPairUsingStream(hashMap);
|
Map.Entry<Integer, String> actualValue = mapFirstPairExample.getFirstPairUsingStream(hashMap);
|
||||||
Map.Entry<Integer, String> expectedValue = new AbstractMap.SimpleEntry<Integer, String>(1, "B");
|
Map.Entry<Integer, String> expectedValue = new AbstractMap.SimpleEntry<Integer, String>(1, "B");
|
||||||
Map.Entry<Integer, String> pairInsertedFirst = new AbstractMap.SimpleEntry<Integer, String>(5, "A");
|
Map.Entry<Integer, String> pairInsertedFirst = new AbstractMap.SimpleEntry<Integer, String>(5, "A");
|
||||||
|
|
||||||
|
@ -55,21 +47,21 @@ public class MapFirstPairServiceUnitTest {
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void whenUsingIteratorForLinkedHashMap() {
|
public void whenUsingIteratorForLinkedHashMap_thenFirstPairWhichWasInsertedFirst() {
|
||||||
Map<Integer, String> linkedHashMap = new LinkedHashMap<>();
|
Map<Integer, String> linkedHashMap = new LinkedHashMap<>();
|
||||||
populateMapValues(linkedHashMap);
|
linkedHashMap = mapFirstPairExample.populateMapValues(linkedHashMap);
|
||||||
Map.Entry<Integer, String> actualValue = mapFirstPairService.getFirstPairUsingIterator(linkedHashMap);
|
Map.Entry<Integer, String> actualValue = mapFirstPairExample.getFirstPairUsingIterator(linkedHashMap);
|
||||||
Map.Entry<Integer, String> expectedValue = new AbstractMap.SimpleEntry<Integer, String>(5, "A");
|
Map.Entry<Integer, String> expectedValue = new AbstractMap.SimpleEntry<Integer, String>(5, "A");
|
||||||
|
|
||||||
assertEquals(expectedValue, actualValue);
|
assertEquals(expectedValue, actualValue);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void whenUsingStreamForLinkedHashMap() {
|
public void whenUsingStreamForLinkedHashMap_thenFirstPairWhichWasInsertedFirst() {
|
||||||
Map<Integer, String> linkedHashMap = new LinkedHashMap<>();
|
Map<Integer, String> linkedHashMap = new LinkedHashMap<>();
|
||||||
populateMapValues(linkedHashMap);
|
linkedHashMap = mapFirstPairExample.populateMapValues(linkedHashMap);
|
||||||
|
|
||||||
Map.Entry<Integer, String> actualValue = mapFirstPairService.getFirstPairUsingStream(linkedHashMap);
|
Map.Entry<Integer, String> actualValue = mapFirstPairExample.getFirstPairUsingStream(linkedHashMap);
|
||||||
Map.Entry<Integer, String> expectedValue = new AbstractMap.SimpleEntry<Integer, String>(5, "A");
|
Map.Entry<Integer, String> expectedValue = new AbstractMap.SimpleEntry<Integer, String>(5, "A");
|
||||||
|
|
||||||
assertEquals(expectedValue, actualValue);
|
assertEquals(expectedValue, actualValue);
|
||||||
|
@ -78,10 +70,10 @@ public class MapFirstPairServiceUnitTest {
|
||||||
@Test
|
@Test
|
||||||
public void whenAddedAnElementInHashMap_thenFirstPairChangedUsingIterator() {
|
public void whenAddedAnElementInHashMap_thenFirstPairChangedUsingIterator() {
|
||||||
Map<Integer, String> hashMap = new HashMap<>();
|
Map<Integer, String> hashMap = new HashMap<>();
|
||||||
populateMapValues(hashMap);
|
hashMap = mapFirstPairExample.populateMapValues(hashMap);
|
||||||
|
|
||||||
hashMap.put(0, "D");
|
hashMap.put(0, "D");
|
||||||
Map.Entry<Integer, String> actualValue = mapFirstPairService.getFirstPairUsingIterator(hashMap);
|
Map.Entry<Integer, String> actualValue = mapFirstPairExample.getFirstPairUsingIterator(hashMap);
|
||||||
Map.Entry<Integer, String> expectedValue = new AbstractMap.SimpleEntry<Integer, String>(0, "D");
|
Map.Entry<Integer, String> expectedValue = new AbstractMap.SimpleEntry<Integer, String>(0, "D");
|
||||||
|
|
||||||
assertEquals(expectedValue, actualValue);
|
assertEquals(expectedValue, actualValue);
|
||||||
|
@ -90,10 +82,10 @@ public class MapFirstPairServiceUnitTest {
|
||||||
@Test
|
@Test
|
||||||
public void whenAddedAnElementInHashMap_thenFirstPairChangedUsingStream() {
|
public void whenAddedAnElementInHashMap_thenFirstPairChangedUsingStream() {
|
||||||
Map<Integer, String> hashMap = new HashMap<>();
|
Map<Integer, String> hashMap = new HashMap<>();
|
||||||
populateMapValues(hashMap);
|
hashMap = mapFirstPairExample.populateMapValues(hashMap);
|
||||||
|
|
||||||
hashMap.put(0, "D");
|
hashMap.put(0, "D");
|
||||||
Map.Entry<Integer, String> actualValue = mapFirstPairService.getFirstPairUsingStream(hashMap);
|
Map.Entry<Integer, String> actualValue = mapFirstPairExample.getFirstPairUsingStream(hashMap);
|
||||||
Map.Entry<Integer, String> expectedValue = new AbstractMap.SimpleEntry<Integer, String>(0, "D");
|
Map.Entry<Integer, String> expectedValue = new AbstractMap.SimpleEntry<Integer, String>(0, "D");
|
||||||
|
|
||||||
assertEquals(expectedValue, actualValue);
|
assertEquals(expectedValue, actualValue);
|
||||||
|
@ -102,10 +94,10 @@ public class MapFirstPairServiceUnitTest {
|
||||||
@Test
|
@Test
|
||||||
public void whenAddedAnElementInLinkedHashMap_thenFirstPairRemainUnchangedUsingIterator() {
|
public void whenAddedAnElementInLinkedHashMap_thenFirstPairRemainUnchangedUsingIterator() {
|
||||||
Map<Integer, String> linkedHashMap = new LinkedHashMap<>();
|
Map<Integer, String> linkedHashMap = new LinkedHashMap<>();
|
||||||
populateMapValues(linkedHashMap);
|
linkedHashMap = mapFirstPairExample.populateMapValues(linkedHashMap);
|
||||||
|
|
||||||
linkedHashMap.put(0, "D");
|
linkedHashMap.put(0, "D");
|
||||||
Map.Entry<Integer, String> actualValue = mapFirstPairService.getFirstPairUsingIterator(linkedHashMap);
|
Map.Entry<Integer, String> actualValue = mapFirstPairExample.getFirstPairUsingIterator(linkedHashMap);
|
||||||
Map.Entry<Integer, String> expectedValue = new AbstractMap.SimpleEntry<Integer, String>(5, "A");
|
Map.Entry<Integer, String> expectedValue = new AbstractMap.SimpleEntry<Integer, String>(5, "A");
|
||||||
|
|
||||||
assertEquals(expectedValue, actualValue);
|
assertEquals(expectedValue, actualValue);
|
||||||
|
@ -114,10 +106,10 @@ public class MapFirstPairServiceUnitTest {
|
||||||
@Test
|
@Test
|
||||||
public void whenAddedAnElementInLinkedHashMap_thenFirstPairRemainUnchangedUsingStream() {
|
public void whenAddedAnElementInLinkedHashMap_thenFirstPairRemainUnchangedUsingStream() {
|
||||||
Map<Integer, String> linkedHashMap = new LinkedHashMap<>();
|
Map<Integer, String> linkedHashMap = new LinkedHashMap<>();
|
||||||
populateMapValues(linkedHashMap);
|
linkedHashMap = mapFirstPairExample.populateMapValues(linkedHashMap);
|
||||||
|
|
||||||
linkedHashMap.put(0, "D");
|
linkedHashMap.put(0, "D");
|
||||||
Map.Entry<Integer, String> actualValue = mapFirstPairService.getFirstPairUsingStream(linkedHashMap);
|
Map.Entry<Integer, String> actualValue = mapFirstPairExample.getFirstPairUsingStream(linkedHashMap);
|
||||||
Map.Entry<Integer, String> expectedValue = new AbstractMap.SimpleEntry<Integer, String>(5, "A");
|
Map.Entry<Integer, String> expectedValue = new AbstractMap.SimpleEntry<Integer, String>(5, "A");
|
||||||
|
|
||||||
assertEquals(expectedValue, actualValue);
|
assertEquals(expectedValue, actualValue);
|
Loading…
Reference in New Issue