
Baeldung Pro comes with both absolutely No-Ads as well as finally with Dark Mode, for a clean learning experience:
Once the early-adopter seats are all used, the price will go up and stay at $33/year.
Last updated: April 7, 2025
In this quick tutorial, we’ll explain how to convert a List of elements to a String. This can be useful in certain scenarios, like printing the contents to the console in a human-readable form for inspection/debugging.
One of the simplest ways is to call the toString() method on the List:
@Test
public void whenListToString_thenPrintDefault() {
List<Integer> intLIst = Arrays.asList(1, 2, 3);
System.out.println(intLIst);
}
Output:
[1, 2, 3]
This technique internally utilizes the toString() method of the type of elements within the List. In our case, we’re using the Integer type, which has a proper implementation of the toString() method.
If we’re using our custom type, such as Person, then we need to make sure that the Person class overrides the toString() method and doesn’t rely on the default implementation. If we don’t properly implement the toString() method, we might get unexpected results:
[org.baeldung.java.lists.ListToSTring$Person@1edf1c96,
org.baeldung.java.lists.ListToSTring$Person@368102c8,
org.baeldung.java.lists.ListToSTring$Person@6996db8]
The String.join() method allows us to concatenate or join multiple String values together with a specified delimiter. It’s a convenient way to combine a collection of Strings into a single String with a custom delimiter between each element.
Let’s first look at how the method joins a String List:
@Test
public void whenStringJoinWithStringList_thenPrintCustom() {
List<String> strList = Arrays.asList("one", "two", "three");
System.out.println(String.join(" : ", strList));
}
Output:
one : two : three
If our elements in the List aren’t subclasses of CharSequence, we can first convert the List to a List<String>, and then pass it to String.join():
@Test
public void whenStringJoinWithNonStringList_thenPrintCustom() {
List<Integer> intList = Arrays.asList(1, 2, 3);
List<String> strList = intList.stream().map(String::valueOf).collect(Collectors.toList());
System.out.println(String.join(" : ", strList));
}
Output:
1 : 2 : 3
In this example, we use Stream.map() and collect() to convert the List<Integer> to a List<String>. Then, we can pass the converted List to String.join() to get the expected output.
In fact, we can simplify this logic by using Collector.joining() without calling String.join() to achieve that. Next, let’s look at how it’s done.
Often, we might need to display the output in a different format.
Compared to the previous example, let’s replace the comma (,) with a hyphen (-), and the square brackets ([, ]) with a set of curly braces ({, }):
@Test
public void whenCollectorsJoining_thenPrintCustom() {
List<Integer> intList = Arrays.asList(1, 2, 3);
String result = intList.stream()
.map(String::valueOf)
.collect(Collectors.joining("-", "{", "}"));
System.out.println(result);
}
Output:
{1-2-3}
The Collectors.joining() method requires a CharSequence, so we need to map the Integer to String. We can utilize this same idea with other classes, even when we don’t have access to the code of the class.
Now we’ll use Apache Commons’ StringUtils class to achieve similar results.
<dependency>
<groupId>org.apache.commons</groupId>
<artifactId>commons-lang3</artifactId>
<version>3.14.0</version>
</dependency>
The latest version of the dependency can be found here.
The implementation is literally a single method call:
@Test
public void whenStringUtilsJoin_thenPrintCustom() {
List<Integer> intList = Arrays.asList(1, 2, 3);
System.out.println(StringUtils.join(intList, "|"));
}
Output:
1|2|3
Again, this implementation is internally dependent on the toString() implementation of the type we’re considering.
In this article, we learned how easy it is to convert a List to a String using different techniques.