Skip to main content

Subtraction two maps by key using Guava library.

In Guava, we have a API work on Maps is difference, we use this API to implement the substraction operator.

Create a maven proj and add below dependency to pom.xml to use this library:
<dependency>
     <groupId>com.google.guava</groupId>
     <artifactId>guava</artifactId>
     <version>18.0</version>
</dependency>

Code:

import java.io.IOException;
import java.util.Map;
import java.util.Map.Entry;
import java.util.Set;

import com.google.common.collect.ImmutableMap;
import com.google.common.collect.MapDifference;
import com.google.common.collect.Maps;

public class App {

    public static void main(final String[] args) throws IOException {
        final Map<String, Integer> left = ImmutableMap.of("a", 1, "b", 2, "c", 3);
        final Map<String, Integer> right = ImmutableMap.of("b", 2, "c", 4, "d", 5);
        final MapDifference<String, Integer> diff = Maps.difference(left, right);
        System.out.println("Common");
        mapToString(diff.entriesInCommon());
        System.out.println("Only Left");
        mapToString(diff.entriesOnlyOnLeft());
        System.out.println("Only Right");
        mapToString(diff.entriesOnlyOnRight());
    }

    private static void mapToString(final Map<String, Integer> map) {
        final Set<Entry<String, Integer>> entrySet = map.entrySet();
        for (final Entry<String, Integer> entry : entrySet) {
            System.out.println(entry.getKey() + "=>" + entry.getValue());
        }
    }
}


Output:
Common
b=>2
Only Left
a=>1
Only Right
d=>5



Comments

Popular posts from this blog

How to Install SQL Server on MacOS with docker

 I'm writing a small tut for who need to install SQL Server on macOS using docker Step 1: Download the SQL Server Image sudo docker pull mcr.microsoft.com/mssql/server:2019-latest Step 2: Launch the SQL Server Image in Docker docker run -d --name example_sql_server -e 'ACCEPT_EULA=Y' -e 'SA_PASSWORD=Pass.word-123' -p 1433:1433 mcr.microsoft.com/mssql/server:2019-latest Step 3: Check the SQL Server Docker Container docker ps -a Step 4: Install SQL Server Command-Line Tool sudo npm install -g sql-cli Step 5: Connect to SQL Server  5.1 Using Command mssql -u sa -p Pass.word-123 5.2: Using VSCode to connect to sql server Using the extension SQL Server (mssql)

Create Grid using React native

After fist post about react native I feel I'm getting familiar with react native, this framework quite easy to use, today I continue with another tutorial about create a simple grid card in react native. Let see the our final result first:                             Let's start... Analytics Assump our data has below structure: We have an array of rows and each row has an array of columns, then I decided to use FlatList to display object in cloumns array in horizontal direction, you can imaging like below image. Gridcard design Card Item each card has a logo and a text. I'm using the Icon from lib react-native-vector-icons To have a flatlist in horizontal we use  horizontal = {true} property, and to make sure the width of flatlist is same as screen with we use  contentContainerStyle={{ flexGrow: 1, justifyContent: 'center' }} Grid Now the implementation quite easy now, just need to...