先自我介绍一下,小编浙江大学毕业,去过华为、字节跳动等大厂,目前阿里P7
深知大多数程序员,想要提升技能,往往是自己摸索成长,但自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!
因此收集整理了一份《2024年最新Golang全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友。
既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,涵盖了95%以上Go语言开发知识点,真正体系化!
由于文件比较多,这里只是将部分目录截图出来,全套包含大厂面经、学习笔记、源码讲义、实战项目、大纲路线、讲解视频,并且后续会持续更新
如果你需要这些资料,可以添加V获取:vip1024b (备注go)
正文
三. 直接内存
直接内存既不是虚拟机内存的一部分, 也不是java虚拟机规范定义的内存区域 (如jdk1.4新加入的NIO)
四. 堆栈
栈:
栈内存用来存储局部变量和方法调用; 是线程私有的; 内存不足抛java.lang.StackOverFlowError
- 栈是由栈帧组成, 每当线程调用一个java方法时,JVM就会在该线程对应的栈中压入一个帧; 帧中存储了对应方法的局部数据, 方法执行完, 则对应的帧从栈中弹出, 并把返回结果存储在调用方法的帧的操作数栈中
- 栈帧组成: 局部变量区、操作数栈、帧数据区
- 局部变量区: 被组织成以一个字长为单位、从0开始计数的数组, short、byte和char的值在存入数组前要被转换成int值, long和double在数组中占据连续的两个字长, 通过索引来访问
- 操作数栈: 被组织成以一个字长为单位的数组, 通过入栈和出栈来访问(临时数据存储区域)
- 帧数据区: 用于支持常量池解析、正常方法返回、异常派发机制
堆:
堆内存用来存储java对象; 是所有线程共有的; 内存不足抛java.lang.OutOfMemoryError
五. 堆内内存和堆外内存
堆内内存
采用垃圾回收器GC统一进行内存管理, GC会在某些特定的时间点对所有分配的堆内内存进行扫描并回收, 这个过程会对java应用程序的性能造成一定影响, 还可能会产生Stop The World
堆外内存
- 即java虚拟机的堆以外的内存, 其直接受操作系统os管理, 可在一定程度上减少垃圾回收对应用程序造成的影响
- 使用java.nio.DirectByteBuffer对象进行堆外内存的管理和使用, DirectByteBuffer类通过成员变量unsafe来操作 对堆外内存的申请
- 优点: 减少了垃圾回收; 堆内在flush到远程时, 会先复制到直接内存, 然后再发送, 而堆外内存省略掉了内存复制这一步操作
- 缺点: 使用堆外内存 间接失去了JVM管理内存的可见性, 当发生内存溢出时排查起来非常困难
System.gc小结
- System.gc方法其实是调用的Runtime.getRuntime.gc(), 而gc方法是native的
- System.gc的作用
1). 做一次full gc
2). 执行后会暂停整个进程
3).System.gc可以使用 -XX:+DisableExplicitGC 禁用
4).常见使用场景如RMI/NIO下的堆外内存分配等
六. HotSpot方法区变迁
1.JDK1.2~JDK6: HotSpot使用永久代和GC分代实现方法区
2.JDK7: HotSpot开始移除永久代; 符号表被移动到 Native Heap中,字符串常量和类引用被移动到 Java Heap中
3.JDK8: 永久代已完全被元空间(Meatspace)取代
七. 永久代变迁产生的影响
八. 参考资料
HOllis<java成神之路系列-基础篇> JVM内存结构
网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。
需要这份系统化的资料的朋友,可以添加V获取:vip1024b (备注Go)
一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!
1jtvKi4-1713327899145)]
一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!