前言
开发项目遇到的小问题,虽说不是大问题,却不遵从开发规范,为了能使代码完美,还是得走向规范之路,让自己的代码越来越完美。
一、判断字符串用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,而且这个是随时自动清除的。
四、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”