Java中,有没有即能高效,又能实现更方便的拼接呢?
StringJoiner:
JDK8才开始的,跟StringBuilder一样,也是用来操作字符串的,也可以看成是一个容器,创建之后里面的内容是可变的。
好处:不仅能提高字符串的操作效率,并且在有些场景下使用它操作字符串,代码会更简洁。
package cn.ensource.d17_stringjoiner;import java.util.StringJoiner;public class Test {public static void main(String[] args) {// 目标:掌握StringJoiner的使用。
// StringJoiner joiner = new StringJoiner(", ");StringJoiner joiner = new StringJoiner(", ", "[", "]");joiner.add("java1");joiner.add("java2");joiner.add("java3");System.out.println(joiner.toString());System.out.println(getArrayData(new int[]{11, 22, 33}));}/*** getArrayData方法*/public static String getArrayData(int[] arr) {// 判断arr是否为nullif (arr == null || arr.length == 0) {return null;}
// StringBuilder sb = new StringBuilder();StringJoiner joiner = new StringJoiner(", ", "[", "]");for (int i = 0; i < arr.length; i++) {joiner.add(arr[i] + "");}return joiner.toString();}
}
运行结果:
之前写过这个程序:
字符串数据排序案例(应用)
有一个字符串:“91 27 46 38 50”,请写程序实现最终输出结果是:“27 38 46 50 91”
这个题目的思路就是把字符串进行分割,然后再将每个小的字符串转成int,然后再进行排序,然后再把int数组中的每个int类型拼接成一个字符串;
package com.company;import java.util.Arrays;public class Main {public static void main(String[] args) {String s = "91 27 46 38 50";//把字符串中的数字存储到一个int类型的数组中String[] strArray = s.split(" ");for(int i=0; i<strArray.length; i++) {System.out.println(strArray[i]);}//定义一个int数组,把String数组的每一个元素存储到int数组中。int[] arr = new int[strArray.length];for(int i=0; i<arr.length; i++) {arr[i] = Integer.parseInt(strArray[i]);}//对int数组进行排序Arrays.sort(arr);//把排序后的int数组中的元素进行拼接到一个字符串,这里拼接采用Stringbuilder来实现StringBuilder sb = new StringBuilder();for(int i=0; i<arr.length; i++) {if(i == arr.length - 1) {sb.append(arr[i]);} else {sb.append(arr[i] + " ");}}String result = sb.toString();System.out.println(result);}
}
现在再看,可以对这个程序也是可以进行优化的。