文章目录

  • ​​前言​​
  • ​​一、判断字符串用equals()而不用==​​
  • ​​二、使用try-with-resource代替传统的关闭流方式​​
  • ​​三、idea 清除所有无效的引用 快捷键​​
  • ​​五、try嵌套、if判断 都合并,无用代码和变量去掉​​
  • ​​六、使用StandardCharsets.UTF_8代替"UTF-8"​​

前言

开发项目遇到的小问题,虽说不是大问题,却不遵从开发规范,为了能使代码完美,还是得走向规范之路,让自己的代码越来越完美。

一、判断字符串用equals()而不用==

==是比较​​两个字符串引用的地址是否相同,即是否指向同一个对象​​​,而equals方法则比较​​字符串的内容是否相同​​​。
例如
String a = “abc”;
String b = “abc”;

a == b返回true,a.equals(b)同样返回true,这是为什么呢?
原来程序在运行时有一个字符串池,创建字符串时会先查找池中是否有相应的字符串,如果已经存在的话只需把引用指向它即可,如果没有则新建一个。
上例中创建a时,会在字符串池中首先创建一个"abc",然后a指向它;创建b时,由于"abc"已经存在,b直接指向它即可。

若改为:
String a = “abc”;
String b = new String(“abc”);
则a == b返回false,a.equals(b)返回true。因为创建b时不管"abc"是否存在都会new一个新的"abc",从而a和b指向的字符创对象是不同的,因此返回false。

二、使用try-with-resource代替传统的关闭流方式

三、idea 清除所有无效的引用 快捷键

Ctrl+alt+o

自动清除的配置方法: 可以settings-general-auto import-java项,勾选optimize imports on the fly,在当前项目下会自动清除无效的import,而且这个是随时自动清除的。

开发项目小问题总结,带有详解解释,让自己的代码走向完美之路,持续更新_bc

五、try嵌套、if判断 都合并,无用代码和变量去掉

if (subUrlList != null) {
if (subUrlList.contains(receiveAlarmUrl)) {
log.info("****初始化:已经订阅****");
break;
}
}

修改为:

if (subUrlList != null && subUrlList.contains(receiveAlarmUrl)) {
log.info("****初始化:已经订阅****");
break;
}

六、使用StandardCharsets.UTF_8代替"UTF-8"

public static String get(String url) {            //  因测试增加的  token  , String token

try (CloseableHttpClient httpclient = HttpClients.createDefault();) {
CloseableHttpResponse response = null;
HttpGet httpget = new HttpGet(url);
// httpget.setHeader("Authorization", token); // 测试用
log.info("executing request " + httpget.getURI());
// 执行get请求
response = httpclient.execute(httpget);
// 获取响应实体
HttpEntity entity = response.getEntity();
// 检验返回码
int statusCode = response.getStatusLine().getStatusCode();
String result = EntityUtils.toString(entity, StandardCharsets.UTF_8);
log.debug("GET请求响应:{}", result);
if (statusCode == HttpStatus.SC_OK) {
return result;
}
} catch (Exception e) {
log.error("GET请求失败:", e);
}
return ConstantUtil.RESPONSE_FAIL;
}

String result = EntityUtils.toString(entity, StandardCharsets.UTF_8);
这一行中,原来我使用的是 “UTF-8”