private static void testStringBuilder() {
System.out.println(“--------------testStringBuilder---------------”);
long beginTime = System.currentTimeMillis();
StringBuilder resultBuilder = new StringBuilder();
resultBuilder.append(url).append(“uId=”).append(uId).append(“&userName=”).append(userName)
.append(“&userPwd=”).append(userPwd);
String resultStr = resultBuilder.toString();
System.out.println(resultStr);
System.out.println(System.currentTimeMillis() - beginTime);
}
private static void testStringAdd() {
System.out.println(“--------------testStringAdd---------------”);
long beginTime = System.currentTimeMillis();
String resultStr = url + “uId=” + uId + “&userName=” + userName + “&userPwd=” + userPwd;
System.out.println(resultStr);
System.out.println(System.currentTimeMillis() - beginTime);
}
public static void main(String[] args) {
testStringFormat();
testStringBuilder();
testStringAdd();
}
}
效果:
可以看到,单纯一次的拼接下,其实三种方式差异基本可以忽略,没什么区别,时间基本可以忽略不计。
接下来我们在每个方法里面都加入循环,而且加入内存占用计算:
private static void testStringFormatFor() {
System.out.println(“--------------testStringFormatFor---------------”);
Runtime runtime = Runtime.getRuntime();
long memory = runtime.freeMemory();
long beginTime = System.currentTimeMillis();
String resultStr=“”;
for (int i = 0; i <= forTimes; i++) {
resultStr = String.format(“%suId=%s&userName=%s&userPwd=%s”, url, uId, userName, userPwd);
}
System.out.println(System.currentTimeMillis() - beginTime);
System.out.println((memory - runtime.freeMemory()) / 10000 + “W”);
}
private static void testStringBuilderFor() {
System.out.println(“--------------testStringBuilderFor---------------”);
Runtime runtime = Runtime.getRuntime();
long memory = runtime.freeMemory();
long beginTime = System.currentTimeMillis();
StringBuilder resultBuilder = new StringBuilder();
for (int i = 0; i <= forTimes; i++) {
resultBuilder.append(url).append(“uId=”).append(uId).append(“&userName=”).append(userName)
.append(“&userPwd=”).append(userPwd);
}
System.out.println(System.currentTimeMillis() - beginTime);
System.out.println((memory - runtime.freeMemory()) / 10000 + “W”);
}
private static void testStringAddFor() {
System.out.println(“--------------testStringAddFor---------------”);
Runtime runtime = Runtime.getRuntime();
long memory = runtime.freeMemory();
long beginTime = System.currentTimeMillis();
String resultStr =null;
for (int i = 0; i <= forTimes; i++) {
resultStr= url + “uId=” + uId + “&userName=” + userName + “&userPwd=” + userPwd;
}
System.out.println(System.currentTimeMillis() - beginTime);
System.out.println((memory - runtime.freeMemory()) / 10000 + “W”);
}
这里循环的次数是 1万次,这样就初步区别出差异了:
最后
自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。
深知大多数Java工程师,想要提升技能,往往是自己摸索成长,自己不成体系的自学效果低效漫长且无助。
因此收集整理了一份《2024年Java开发全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。
既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上Java开发知识点,不论你是刚入门Android开发的新手,还是希望在技术上不断提升的资深开发者,这些资料都将为你打开新的学习之门!
如果你觉得这些内容对你有帮助,需要这份全套学习资料的朋友可以戳我获取!!
由于文件比较大,这里只是将部分目录截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且会持续更新!
刚入门Android开发的新手,还是希望在技术上不断提升的资深开发者,这些资料都将为你打开新的学习之门!**
如果你觉得这些内容对你有帮助,需要这份全套学习资料的朋友可以戳我获取!!
由于文件比较大,这里只是将部分目录截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且会持续更新!