jvm逻辑框架
来源:互联网 发布:福利rtmp网络串流地址 编辑:程序博客网 时间:2024/06/08 06:04
java堆(JavaHeap)
1.用来存放对象的,几乎所有对象都放在这里,被线程共享的,或者说是被栈共享的
2.堆又可以分为新生代和老年代,实际还有一个区域叫永久代,但是jdk1.7已经去永久代了,所以可以当作没有,永久代是当jvm启动时就存放的JDK自身的类和接口数据,关闭则释放。
新生代可以分为Eden区和两个幸存区,这么设计是为了更好地利用内存 之前的设计是只分为两部分一样一半 后来发现这样只利用到了一半的内存 才改为按比例分成三个区的,使用的是复制回收算法,两个幸存区是较小的区域。逻辑是每次使用Eden区和其中一个幸存区,回收时将其还存活着的对象一次性的复制到另一个幸存区中,最后清理到刚才使用的Eden和其中一个幸存区。
美团的面试官也问了这个问题,他也说了他的理解,我感觉可能是不准确的。
新建对象就在Eden区,Eden就是伊甸,顾名思义。但是并不是对象最活跃的区域,对象最活跃的区域是老年代,因为经过各种垃圾回收之后对象都跑到这里来了。
3.内存溢出
内存溢出其实没什么好讲的,满了就会溢出。怎么才能满呢,不断创建对象,那问题又来了,创建多了被回收怎么办,好办,将新建的对象存到list里去,就不会回收了,为什么呢,因为jvm判定一个对象的死活就是根据对象是不是被引用。
此外堆跟随jvm的,有jvm就有堆。堆也是垃圾回收的主要区域,又叫GC堆,垃圾堆,玩笑。
jvm栈
1.要说栈是用来存什么的,其实我感觉不严谨,栈是运行时创建的,是跟随线程的,它不是用来存什么的,那它用来干什么的,它是用来存栈帧的,没有图不太好说呢,等下我去截个图。
图来了我就不用多说了。每个栈帧其实可以理解为一个方法,我是这么理解的,之间的关系就是调用。
2.栈的好处就是不需要垃圾回收,随着线程结束内存就释放。
3.但是并不是说就不会内存溢出,那么栈的内存溢出是怎么产生的呢,肯定也是满了,这个满了怎么理解呢,一是要申请的不够了,二是jvm内存太小,这是个有趣的问题。但是产生的错误却是不一样的,如果创建一个void方法调用自身,错误是stackoverflowError,如果不断创建线程则会outOfMemoryError。这里就有一个比较高级的问题了,对于第二种多线程内存溢出该怎么解决呢,深入理解jvm一书中给出的解决方案是这样的,通过减小最大堆和栈容量来换取更多的线程。
方法区和运行时常量池
1.方法区是堆的一个逻辑区域,但是又叫非堆。运行时常量池又是方法区的一部分,真正的一部分。方法区并不是存方法的,存方法的应该是栈或者栈帧。方法区存的是类信息、常量、静态变量等,也是被线程共享的区域。运行时常量池存放的是编译期生产的各种字面量和符号引用。
2.这块内存区域的回收没啥好说的,因为我也不太清楚,我只知道HotSpot的设计团队选择把GC分代扩展至方法区了,或者是使用永久代实现方法区。
3.内存是肯定会溢出的,不断创建类会导致方法区内存溢出,而不断将常量放入常量池(String.intern()),常量池也会内存溢出。
内存是jvm的重点区域,也是jvm优化的重点区域,既然这么重要一下子也不可能写完了,慢慢学习补充吧。
- jvm逻辑框架
- 关于JVM问题(逻辑框架)
- JVM内存逻辑结构
- jvm框架
- jvm hotspot gc 逻辑 脑图
- Drools业务逻辑框架
- 模糊逻辑系统框架
- 代码逻辑框架
- ofbiz框架逻辑流程图
- 框架-逻辑层
- 框架-逻辑层
- JVM之一-总体框架
- 轻量级业务逻辑处理框架
- SSH框架的逻辑流程
- shiro框架权限验证逻辑
- 游戏服务端逻辑模块处理框架
- shiro安全框架|基础知识:登录逻辑
- 框架业务逻辑分析——经典!!!!!!!!!!!!
- Android控件点击监听事件失效
- Centos6.5上搭建FTP远程yum源
- 九宫格动画
- ES6-对象的扩展-对象的扩展运算符
- BP神经网络工作原理
- jvm逻辑框架
- 马云:与其担心技术夺走就业,不如拥抱技术、解决新问题
- 技术干货:使用静态缓存提升网站性能的五种方法!
- Aras Innovator: TOC category的视图
- apk签名的别名忘记的解决方法
- iOS开发 ☞ 苹果审核准则
- 交互式SQL-简单查询、连接查询和聚合查询
- 欢迎使用CSDN-markdown编辑器
- 重装系统后重装 mysql(windows)