Java 集合或數組轉變爲逗號分隔的字符串的幾種方式

首先,創建一個集合

	List<String> list = Lists.newArrayList(null, "bob", "jack");

1、自己編碼實現

    public static <T> String join(List<T> list, String splitStr) {
        if (CollectionUtils.isEmpty(list))
            return "";
        if (list.size() == 1)
            return String.valueOf(list.get(0));
        StringBuilder sb = new StringBuilder();
        boolean isFirst = true;
        for (int i = 0; i < list.size(); i++) {
            if (!isFirst) sb.append(splitStr);
            sb.append(String.valueOf(list.get(i)));
            isFirst = false;
        }
        return sb.toString();
    }

    public static <T> String join(T[] array, String splitStr) {
        if (ArrayUtils.isEmpty(array))
            return "";
        if (array.length == 1)
            return String.valueOf(array[0]);
        StringBuilder sb = new StringBuilder();
        boolean isFirst = true;
        for (int i = 0; i < array.length; i++) {
            if (!isFirst) sb.append(splitStr);
            sb.append(String.valueOf(array[i]));
            isFirst = false;
        }
        return sb.toString();
    }

輸出

	null,bob,jack

2、org.apache.commons.lang3.StringUtils

	System.out.println(StringUtils.join(list.toArray(), ","));

輸出

	,bob,jack

3、StringJoiner, JDK1.8+

	StringJoiner sj = new StringJoiner(",");
	list.forEach(e -> sj.add(String.valueOf(e)));
	System.out.println(sj.toString());
	
	// 在連接之前操作字符串, 拼接前綴和後綴
	StringJoiner sj2 = new StringJoiner(",", "START_", "_END");
	list.forEach(e -> sj2.add(String.valueOf(e)));
	System.out.println(sj2.toString());

輸出

	null,bob,jack
	START_null,bob,jack_END

4、String.join(), JDK1.8+

	System.out.println(String.join(",", list));

輸出

	null,bob,jack

5、Stream, Collectors.joining(), JDK1.8+

	System.out.println(list.stream().collect(Collectors.joining(",")));
	
	// 在連接之前操作字符串, 拼接前綴和後綴
	String str = list.stream().map(e -> {
	   if (e != null) return e.toUpperCase();
	   else return "null";
	}).collect(Collectors.joining(",", "START_", "_END"));
	System.out.println(str);

輸出

	null,bob,jack
	START_null,BOB,JACK_END
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章