我使用的是org.apache.commons.lang3.StringUtils中的strip(String str, String stripChars)方法
下面举个例子,比如我要删除oldStr中前后的{}
String oldStr = "{[Hello,word!!!]}";
//返回结果:[Hello,word!!!]
String newStr = StringUtils.strip(str, "{}");
那为什么他能删除首尾指定字符串呢,下面我们来看看源码
public static String strip(String str, String stripChars) {
str = stripStart(str, stripChars);
return stripEnd(str, stripChars);
}
可以看出他调用了另外两个方法,那我们来依次看下
public static String stripStart(String str, String stripChars) {
//获取对象字符串长度
int strLen = length(str);
if (strLen == 0) {
return str;
} else {
int start = 0;
if (stripChars == null) {
while(start != strLen && Character.isWhitespace(str.charAt(start))) {
++start;
}
} else {
if (stripChars.isEmpty()) {
return str;
}
//关键点:众所周知,substring()方法是截取从当前索引开始直到末尾的字符串并返回,
//而这一步的目的,就是为了获取str中开端包含需要删除的字符串的索引位置
while(start != strLen && stripChars.indexOf(str.charAt(start)) != -1) {
++start;
}
}
return str.substring(start);
}
}
//与上一个方法相同,只是截取掉的字段变成了末尾
public static String stripEnd(String str, String stripChars) {
int end = length(str);
if (end == 0) {
return str;
} else {
if (stripChars == null) {
while(end != 0 && Character.isWhitespace(str.charAt(end - 1))) {
--end;
}
} else {
if (stripChars.isEmpty()) {
return str;
}
while(end != 0 && stripChars.indexOf(str.charAt(end - 1)) != -1) {
--end;
}
}
return str.substring(0, end);
}
}