最后
小编在这里分享些我自己平时的学习资料,由于篇幅限制,pdf文档的详解资料太全面,细节内容实在太多啦,所以只把部分知识点截图出来粗略的介绍,每个小节点里面都有更细化的内容!
开源分享:【一线大厂Java面试题解析+核心总结学习笔记+最新讲解视频+实战项目源码】
程序员代码面试指南 IT名企算法与数据结构题目最优解
这是” 本程序员面试宝典!书中对IT名企代码面试各类题目的最优解进行了总结,并提供了相关代码实现。针对当前程序员面试缺乏权威题目汇总这一-痛点, 本书选取将近200道真实出现过的经典代码面试题,帮助广“大程序员的面试准备做到万无一失。 “刷”完本书后,你就是“题王”!
《TCP-IP协议组(第4版)》
本书是介绍TCP/IP协议族的经典图书的最新版本。本书自第1版出版以来,就广受读者欢迎。
本书最新版进行」护元,以体境计算机网络技不的最新发展,全书古有七大部分共30草和7个附录:第一部分介绍一些基本概念和基础底层技术:第二部分介绍网络层协议:第三部分介绍运输层协议;第四部分介绍应用层协议:第五部分介绍下一代协议,即IPv6协议:第六部分介绍网络安全问题:第七部分给出了7个附录。
Java开发手册(嵩山版)
这个不用多说了,阿里的开发手册,每次更新我都会看,这是8月初最新更新的**(嵩山版)**
MySQL 8从入门到精通
本书主要内容包括MySQL的安装与配置、数据库的创建、数据表的创建、数据类型和运算符、MySQL 函数、查询数据、数据表的操作(插入、更新与删除数据)、索引、存储过程和函数、视图、触发器、用户管理、数据备份与还原、MySQL 日志、性能优化、MySQL Repl ication、MySQL Workbench、 MySQL Utilities、 MySQL Proxy、PHP操作MySQL数据库和PDO数据库抽象类库等。最后通过3个综合案例的数据库设计,进步讲述 MySQL在实际工作中的应用。
Spring5高级编程(第5版)
本书涵盖Spring 5的所有内容,如果想要充分利用这一领先的企业级 Java应用程序开发框架的强大功能,本书是最全面的Spring参考和实用指南。
本书第5版涵盖核心的Spring及其与其他领先的Java技术(比如Hibemate JPA 2.Tls、Thymeleaf和WebSocket)的集成。本书的重点是介绍如何使用Java配置类、lambda 表达式、Spring Boot以及反应式编程。同时,将与企业级应用程序开发人员分享一些见解和实际经验,包括远程处理、事务、Web 和表示层,等等。
JAVA核心知识点+1000道 互联网Java工程师面试题
企业IT架构转型之道 阿里巴巴中台战略思想与架构实战
本书讲述了阿里巴巴的技术发展史,同时也是-部互联网技 术架构的实践与发展史。
-
执行速度StringBuilder > StringBuffer > String。
-
StringBuilder是非线程安全的,StringBuffer是线程安全的。
2、效率测试
import java.util.ArrayList;
import java.util.List;
import java.util.StringJoiner;
public class StringTest {
private static void test01() {
String str = “哪吒,”;
String ret = “”;
System.out.println(“+字符串拼接开始…”);
long start = System.currentTimeMillis();
// + 在循环中的效率太低,用10万条测试吧
for (int i = 0; i < 100000; i++) {
ret += str;
}
long end = System.currentTimeMillis();
System.out.println(“+号拼接10万条数据耗时:”+(end-start)+“ms”);//18288ms
System.out.println(“************”);
}
private static void test02() {
String str = “哪吒,”;
StringBuilder builder = new StringBuilder();
System.out.println(“StringBuilder,字符串拼接开始…”);
long start = System.currentTimeMillis();
for (int i = 0; i < 10000000; i++) {
builder.append(str);
}
long end = System.currentTimeMillis();
System.out.println(“StringBuilder拼接1000万条数据耗时:”+(end-start)+“ms”);//168ms,173ms,239ms
System.out.println(“************”);
}
private static void test03() {
String str = “哪吒,”;
StringBuffer buffer = new StringBuffer();
System.out.println(“StringBuffer,字符串拼接开始…”);
long start = System.currentTimeMillis();
for (int i = 0; i < 10000000; i++) {
buffer.append(str);
}
long end = System.currentTimeMillis();
System.out.println(“StringBuffer拼接1000万条数据耗时:”+(end-start)+“ms”);//527ms,343ms,398ms
System.out.println(“************”);
}
/**
- StringJoiner的效率明显高于List + StringJoiner
*/
private static void test04() {
String str = “哪吒”;
StringJoiner join = new StringJoiner(“,”);
System.out.println(“StringJoiner,字符串拼接开始…”);
long start = System.currentTimeMillis();
for (int i = 0; i < 10000000; i++) {
join.add(str);
}
long end = System.currentTimeMillis();
System.out.println(“StringJoiner拼接1000万条数据耗时:”+(end-start)+“ms”);//184ms,316ms,243ms
System.out.println(“************”);
}
private static void test05() {
String str = “哪吒”;
List list = new ArrayList();
System.out.println(“List + StringJoiner,字符串拼接开始…”);
long start = System.currentTimeMillis();
for (int i = 0; i < 10000000; i++) {
list.add(str);
}
String ret = String.join(“,”, list);
long end = System.currentTimeMillis();
System.out.println(“List + StringJoiner拼接1000万条数据耗时:”+(end-start)+“ms”);//563ms,477ms,585ms
System.out.println(“************”);
}
public static void main(String[] args) {
test02();
}
}
3、控制台输出
总结:StringBuilder效率最高,+拼接效率最低。
4、源码分析
StringBuilder的源码
@Override
public StringBuilder append(char[] str) {
super.append(str);
return this;
}
StringBuilder继承AbstractStringBuilder
类
public final class StringBuilder
extends AbstractStringBuilder
implements java.io.Serializable, CharSequence
{
…
}
public AbstractStringBuilder append(String str) {
if (str == null)
return appendNull();
int len = str.length();
ensureCapacityInternal(count + len);
str.getChars(0, len, value, count);
count += len;
return this;
}
append会直接拷贝字符到内部的字符数组中,如果字符数组长度不够,会进行扩展。
StringBuffer和StringBuilder的情况类似,只不过StringBuffer是线程安全的而已。
四、字符串常量池
1、百度百科
常量池在java用于保存在编译期已确定的,已编译的class文件中的一份数据。它包括了关于类,方法,接口等中的常量,也包括字符串常量,如String s = "java"这种申明方式;当然也可扩充,执行器产生的常量也会放入常量池,故认为常量池是JVM的一块特殊的内存空间。
2、字符串的对象分配
字符串的对象分配是需要消耗大量的时间和空间的,而且字符串使用的非常多,很多初级程序员,会将所有的变量都定义为String,不知你年轻的时候是不是这样,哈哈。
JVM为了提高性能和减少内存的开销,在实例化字符串的时候进行了一系列的优化,那就是字符串常量池。JVM会先检查字符串常量池,如果已经存在,就直接返回字符串常量池中的实例引用,如果不存在,就会实例化该字符串并将其放到字符串常量池中。由于String的不可变性,常量池中一定不存在两个相同的字符串。
3、内存区域
在HotSpot VM中字符串常量池是通过一个StringTable类实现的,它是一个Hash表,默认值大小长度是1009;这个StringTable在每个HotSpot VM的实例中只有一份,被所有的类共享;字符串常量由一个一个字符组成,放在了StringTable上。要注意的是,如果放进String Pool的String非常多,就会造成Hash冲突严重,从而导致链表会很长,而链表长了后直接会造成的影响就是当调用String.intern时性能会大幅下降。
4、举个例子一目了然
public class StringTest {
public static void main(String[] args) {
// 1. 新建一个引用s1指向堆中的对象s1,值为"CSDN哪吒"
String s1=new String(“CSDN”)+new String(“哪吒”);
// 2. 新建一个引用s2指向堆中的对象s2,值为"CSDN哪吒"
String s2=new String(“CS”)+new String(“DN哪吒”);
// 3. 执行s1.intern()会在字符串常量池中新建一个引用"CSDN哪吒",该引用指向s1在堆中的地址,并新建一个引用s3指向字符串常量池中的"CSDN哪吒"
最后
作为过来人,小编是整理了很多进阶架构视频资料、面试文档以及PDF的学习资料,针对上面一套系统大纲小编也有对应的相关进阶架构视频资料
DN哪吒"
最后
作为过来人,小编是整理了很多进阶架构视频资料、面试文档以及PDF的学习资料,针对上面一套系统大纲小编也有对应的相关进阶架构视频资料
[外链图片转存中…(img-RQbPCm0F-1715230010420)]
[外链图片转存中…(img-54Jc6zBY-1715230010421)]