sb.append(c);作用是什么,可以用别的代码替换吗
时间: 2024-02-27 14:53:05 浏览: 55
sb.append(c) 的作用是将字符 c 添加到 StringBuilder 对象 sb 的末尾。这个方法会返回 StringBuilder 对象本身,因此可以链式调用。
如果你希望将字符添加到字符串中,可以使用字符串拼接操作符 + 或 String 类的 concat() 方法。例如:
```java
String str = "hello";
char c = '!';
str = str + c; // 使用字符串拼接操作符 +
// 或者
str = str.concat(String.valueOf(c)); // 使用 concat() 方法
```
如果不想使用 StringBuilder 对象,你也可以使用 StringBuffer 对象来进行字符串拼接操作。但是需要注意的是,StringBuffer 是线程安全的,而 StringBuilder 不是,因此如果需要在多线程环境下使用,应该使用 StringBuffer。
相关问题
public static String format(final String strPattern, final Object... argArray) { if (StringUtils.isEmpty(strPattern) || StringUtils.isEmpty(argArray)) { return strPattern; } final int strPatternLength = strPattern.length(); // 初始化定义好的长度以获得更好的性能 StringBuilder sbuf = new StringBuilder(strPatternLength + 50); int handledPosition = 0; int delimIndex;// 占位符所在位置 for (int argIndex = 0; argIndex < argArray.length; argIndex++) { delimIndex = strPattern.indexOf(EMPTY_JSON, handledPosition); if (delimIndex == -1) { if (handledPosition == 0) { return strPattern; } else { // 字符串模板剩余部分不再包含占位符,加入剩余部分后返回结果 sbuf.append(strPattern, handledPosition, strPatternLength); return sbuf.toString(); } } else { if (delimIndex > 0 && strPattern.charAt(delimIndex - 1) == C_BACKSLASH) { if (delimIndex > 1 && strPattern.charAt(delimIndex - 2) == C_BACKSLASH) { // 转义符之前还有一个转义符,占位符依旧有效 sbuf.append(strPattern, handledPosition, delimIndex - 1); sbuf.append(Convert.utf8Str(argArray[argIndex])); handledPosition = delimIndex + 2; } else { // 占位符被转义 argIndex--; sbuf.append(strPattern, handledPosition, delimIndex - 1); sbuf.append(C_DELIM_START); handledPosition = delimIndex + 1; } } else { // 正常占位符 sbuf.append(strPattern, handledPosition, delimIndex); sbuf.append(Convert.utf8Str(argArray[argIndex])); handledPosition = delimIndex + 2; } } } // 加入最后一个占位符后所有的字符 sbuf.append(strPattern, handledPosition, strPattern.length()); return sbuf.toString(); }优化这段代码
这段代码是一个字符串格式化方法,可以将字符串中的占位符替换为对应的参数值。以下是一些优化建议:
1. 使用StringBuilder代替String进行字符串拼接,因为StringBuilder的效率更高。
2. 将字符串常量提取到常量池中,避免每次循环都创建新的字符串对象。
3. 使用 enhanced for 循环代替传统的 for 循环,可以提高代码的可读性。
4. 使用 StringUtils.isNotEmpty() 方法代替 StringUtils.isEmpty() 方法取反。
5. 将 Convert.utf8Str() 方法提取出来,避免在循环中多次调用。
6. 将字符串的长度缓存下来,避免每次循环都调用 length() 方法。
优化后的代码如下:
```
public static String format(final String strPattern, final Object... argArray) {
if (StringUtils.isNotEmpty(strPattern) && argArray != null && argArray.length > 0) {
final int strPatternLength = strPattern.length();
StringBuilder sb = new StringBuilder(strPatternLength + 50);
int handledPosition = 0;
int delimIndex;// 占位符所在位置
for (Object arg : argArray) {
delimIndex = strPattern.indexOf(EMPTY_JSON, handledPosition);
if (delimIndex == -1) {
if (handledPosition == 0) {
return strPattern;
} else {
// 字符串模板剩余部分不再包含占位符,加入剩余部分后返回结果
sb.append(strPattern, handledPosition, strPatternLength);
return sb.toString();
}
} else {
if (delimIndex > 0 && strPattern.charAt(delimIndex - 1) == C_BACKSLASH) {
if (delimIndex > 1 && strPattern.charAt(delimIndex - 2) == C_BACKSLASH) {
// 转义符之前还有一个转义符,占位符依旧有效
sb.append(strPattern, handledPosition, delimIndex - 1);
sb.append(Convert.utf8Str(arg));
handledPosition = delimIndex + 2;
} else {
// 占位符被转义
sb.append(strPattern, handledPosition, delimIndex - 1);
sb.append(C_DELIM_START);
handledPosition = delimIndex + 1;
continue;
}
} else {
// 正常占位符
sb.append(strPattern, handledPosition, delimIndex);
sb.append(Convert.utf8Str(arg));
handledPosition = delimIndex + 2;
}
}
}
// 加入最后一个占位符后所有的字符
sb.append(strPattern, handledPosition, strPatternLength);
return sb.toString();
}
return strPattern;
}
```
小明写了一段代码,想实现替换文件部分内容的目标,但是代码似乎写得有些问题,请你纠正并优化这段代码,并给出你的优化逻辑,优化点多多益善。 public static void main(String[] args) throws IOException { File file = new File("some file path"); List list1 = new ArrayList(); FileInputStream fileInputStream = new FileInputStream(file); byte[] bytes = new byte[1024]; int i = fileInputStream.read(bytes); if(i > 0) { do { i = fileInputStream.read(bytes); String s = new String(bytes, 0 , i); list1.add(s); } while(i != -1); } i = fileInputStream.read(bytes); String start = new String(bytes, 0, i); list1.add(start); for (int i1 = 0; i1 < list1.size(); i1++) { String s = (String) list1.get(i1); if(s.contains("1")) { s = s.replace("1", "a"); } else if(s.contains("2")) { s = s.replace("2", "b"); } else if(s.contains("3")) { s = s.replace("3", "c"); } else if(s.contains("4")) { s = s.replace("4", "d"); } list1.remove(i1); list1.add(i1, s); } FileOutputStream fos = new FileOutputStream(file); for (Object o : list1) { fos.write(o.toString().getBytes()); } }
以下是我对代码的优化和修改建议:
1. 在定义List时,应该指定泛型类型,避免出现未经检查的转换警告。
2. 在读取文件内容时,应该使用try-with-resources语句,避免忘记关闭文件流导致资源泄漏。
3. 在读取文件内容时,应该使用StringBuilder来拼接字符串,避免频繁的对象创建和销毁。
4. 在读取文件内容时,应该使用while循环来读取文件内容,避免只读取了一部分内容。
5. 在替换文件内容时,应该使用StringBuilder来进行替换,避免频繁的对象创建和销毁。
6. 在替换文件内容时,应该使用正则表达式来进行替换,可以更加灵活方便。
7. 在遍历List时,应该使用Iterator来遍历,避免在遍历时修改List导致ConcurrentModificationException异常。
8. 在写入文件时,应该使用try-with-resources语句,避免忘记关闭文件流导致资源泄漏。
9. 在写入文件时,应该使用byte[]数组来一次性写入数据,避免频繁的IO操作。
10. 在文件操作时,应该进行异常处理,避免程序出现异常而导致程序崩溃。
综上所述,以下是我优化后的代码:
public static void main(String[] args) {
File file = new File("some file path");
List<String> list1 = new ArrayList<>();
try (FileInputStream fileInputStream = new FileInputStream(file);
InputStreamReader inputStreamReader = new InputStreamReader(fileInputStream, StandardCharsets.UTF_8);
BufferedReader bufferedReader = new BufferedReader(inputStreamReader)) {
StringBuilder sb = new StringBuilder();
String line;
while ((line = bufferedReader.readLine()) != null) {
sb.append(line).append(System.lineSeparator());
}
String content = sb.toString();
content = content.replaceAll("1", "a")
.replaceAll("2", "b")
.replaceAll("3", "c")
.replaceAll("4", "d");
try (FileOutputStream fos = new FileOutputStream(file)) {
fos.write(content.getBytes(StandardCharsets.UTF_8));
}
} catch (IOException e) {
e.printStackTrace();
}
}
阅读全文