我正在努力从StringBuilder中删除一些字符。这种方法效果很好。但是,我想通过Java-8StreamsAPI实现同样的目标。当前代码是冗长的。有没有办法通过Java8StreamsAPI重构第二个方法removeCarryReturnsCharacters()?
private static StringBuilder readEntireFileUsingStream(Path filePath) throws IOException {
StringBuilder data = new StringBuilder(String.valueOf(Files.readAllLines(filePath, StandardCharsets.ISO_8859_1)));
return removeCarryReturnsCharacters(data);
}
private static StringBuilder removeCarryReturnsCharacters(StringBuilder fileData){
int endIndex = 1012;
String needToRemove = "";
long totDataChunkCount = fileData.length()/1014;
long delCounter = 1;
try{
while (delCounter < totDataChunkCount) {
needToRemove = fileData.substring(endIndex, endIndex + 2);
if (needToRemove.equals("^^")) {
fileData.delete(endIndex, endIndex + 2);
}
endIndex += 1012;
delCounter++;
}
}catch(StringIndexOutOfBoundsException exp){
throw exp;
}
return fileData;
}发布于 2018-05-08 07:49:44
由于缺乏Stream,当前的代码并不冗长,而是大量不必要的操作:
needToRemove = "";已过时delCounter和endIndex。while循环,尽管您有一个具有初始语句、条件和增量操作的经典计数循环,确切地说,for循环是为long变量来表示绝对不会超过int值范围的值try … catch块,只需重新抛出捕获的异常。needToRemove变量来保存对象;您可以简单地检查if(fileData.substring(endIndex, endIndex + 2).equals("^^")),或者像我希望的那样只检查两个字符,
if(fileData.charAt(endIndex)=='^' && fileData.charAt(endIndex+1)=='^')解决所有这些问题将使方法变为
private static StringBuilder removeCarryReturnsCharacters(StringBuilder fileData) {
for(int endIndex = 1012; endIndex < fileData.length(); endIndex += 1012)
if(fileData.charAt(endIndex) == '^' && fileData.charAt(endIndex+1) == '^')
fileData.delete(endIndex, endIndex + 2);
return fileData;
}我不认为重写循环以使用Stream会带来任何额外的好处。
https://stackoverflow.com/questions/50227172
复制相似问题