Course – LS – All

Get started with Spring and Spring Boot, through the Learn Spring course:

>> CHECK OUT THE COURSE

1. Introduction

Java’s HashMap class is a widely used data structure that stores key-value pairs.

In this tutorial, we’ll delve into the process of converting a HashMap‘s string representation, obtained through the toString() method, back to a HashMap object in Java.

2. Understanding HashMap String Representation

Before we dive into the conversion process, let’s gain a solid understanding of HashMap and its String representation. Each key within a HashMap is uniquely linked to a corresponding value, offering efficient data retrieval based on these keys.

Moreover, the toString() method in HashMap provides a string representation of the map, encapsulating all its key-value pairs.

In certain scenarios, we might encounter a HashMap‘s string representation from external sources, such as files or network requests. Hence, to effectively work with this data, it’s imperative to reconstitute the string representation into a usable HashMap object. This conversion process involves meticulous string parsing to extract the key-value pairs.

3. The Conversion Process

Let’s look at the steps required to convert a HashMap‘s string representation to a corresponding HashMap object:

  • Obtain the String representation: Begin by acquiring the string representation of the HashMap, either from external sources or through manual creation.
  • Remove extraneous characters: The string representation obtained via toString() often includes extraneous characters like curly braces {} and spaces. Eliminate these characters to isolate the essential key-value pairs.
  • Split into key-value pairs: Subsequently, dissect the modified string into discrete key-value pair strings. These pairs are typically demarcated by commas.
  • Parsing key-value pairs: For each key-value pair string, dissect it into individual key and value components. These components can be separated by the equal sign (=) or another chosen delimiter.
  • Construct a new HashMap: For each extracted key-value pair, forge a new entry in a HashMap by associating the key with its corresponding value.
  • Error handling: Throughout the parsing process, exercise diligence in handling exceptions that may arise due to erroneous formatting or unexpected input.

4. Handling Simple Conversion

Let’s look at examples to solidify our understanding of the conversion process. In our example, we’ll demonstrate the conversion of a HashMap‘s string representation back into a HashMap object:

String hashMapString = "{key1=value1, key2=value2, key3=value3}";
String keyValuePairs = hashMapString.replaceAll("[{}\\s]", "");
String[] pairs = keyValuePairs.split(",");

HashMap<String, String> actualHashMap = new HashMap<>();

for (String pair : pairs) {
    String[] keyValue = pair.split("=");
    if (keyValue.length == 2) {
        actualHashMap.put(keyValue[0], keyValue[1]);
    }
}

The code involves removing unnecessary characters from the input string, splitting it into key-value pairs, and populating a new HashMap accordingly.

5. Handling Complex Conversion

When a HashMap contains complex types as values, such as custom objects, the process of converting the string representation back to a HashMap object becomes more intricate. Custom logic is needed to deserialize these complex objects from their string representations during the parsing process.

To illustrate this, let’s consider an example using a ConvertHashMapStringToHashMapObjectUsingtoString class. This class is equipped with a custom toString() method to facilitate serialization:

class ConvertHashMapStringToHashMapObjectUsingtoString {
    private String name;
    private int age;

    public ConvertHashMapStringToHashMapObjectUsingtoString (String name, int age) {
        this.name = name;
        this.age = age;
    }

    @Override
    public String toString() {
        return "{name=" + name + ", age=" + age + "}";
    }
}

Next, let’s create a deserializeCustomObject() method that can be used to deserialize the custom object from its string representation:

private static ConvertHashMapStringToHashMapObjectUsingtoString deserializeCustomObject(String valueString) {
    if (valueString.startsWith("{") && valueString.endsWith("}")) {
        valueString = valueString.substring(1, valueString.length() - 1);
        String[] parts = valueString.split(",");
        String name = null;
        int age = -1;

        for (String part : parts) {
            String[] keyValue = part.split("=");
            if (keyValue.length == 2) {
                String key = keyValue[0].trim();
                String val = keyValue[1].trim();
                if (key.equals("name")) {
                    name = val;
                } else if (key.equals("age")) {
                    age = Integer.parseInt(val);
                }
            }
        }

        if (name != null && age >= 0) {
            return new ConvertHashMapStringToHashMapObjectUsingtoString(name, age);
        }
    }

    return new ConvertHashMapStringToHashMapObjectUsingtoString("", -1);
}

Now, let’s demonstrate how to use this logic to deserialize a HashMap with custom objects as values:

public static void main(String[] args) {
    String hashMapString = "{key1={name=John, age=30}, key2={name=Alice, age=25}}";

    String keyValuePairs = hashMapString.replaceAll("[{}\\s]", "");

    String[] pairs = keyValuePairs.split(",");

    Map<String, ConvertHashMapStringToHashMapObjectUsingtoString> actualHashMap = new HashMap<>();

    for (String pair : pairs) {
        String[] keyValue = pair.split("=");
        if (keyValue.length == 2) {
            String key = keyValue[0];
            ConvertHashMapStringToHashMapObjectUsingtoString value = deserializeCustomObject(keyValue[1]);
            actualHashMap.put(key, value);
        }
    }

    System.out.println(actualHashMap);
}

5. Conclusion

Converting a HashMap‘s string representation back to a HashMap in Java involves a systematic process of parsing and populating key-value pairs.

By following the steps outlined in this article and utilizing the provided example, we can effectively convert HashMap strings into usable HashMap objects.

This ability is particularly useful when dealing with data received from external sources or when serializing and deserializing HashMaps.

As always, the complete code samples for this article can be found over on GitHub.

Course – LS – All

Get started with Spring and Spring Boot, through the Learn Spring course:

>> CHECK OUT THE COURSE
res – REST with Spring (eBook) (everywhere)
Comments are open for 30 days after publishing a post. For any issues past this date, use the Contact form on the site.