让你第一次认识到Java的内存管理
发现之前写的可读性不好,这次准备试试换风格,去掉长篇大论,觉得这个风格好的,麻烦点个赞啦
清理、JVM的妙处
大家以后都是程序员,假设你很不幸,需要自己交钱租房子。
你作为一个小穷人,租的房子到期了(万一是你跳槽去了其他地方,滑稽),房子就要还给房东。
在很久之前,**房东C++**是个好人,等着房客主动来还房子,然后再把房子租出去(析构)。
这里C++只是说在堆上分配内存,而不是栈,求C++大佬们放过!!对不起!
后来叫Java的也来做了房东,Java很有钱,他有一栋大楼的房子,Java会给所有的租客一个叫内存的卡(new操作):
- 在客户多的时候,定期给租期还没到的人发新卡分配住处
- 在客户少的时候,Java就会喊所有人以及他认识的租客(活对象、引用链)来前台,给他们的卡上做个标记,这时溜号的人就没有这个标记,然后Java会把没有这个标记的人的房间重置用来下次租。
上面两种方式就是C++中的析构(还房子)与**Java的内存管理方式——垃圾回收(GC)**中的两种方式“停止-复制”与“标记-清扫”。
但是,Java有一些客户,是从C++和其他房东那里,借用客户的关系挖来的,他们的房子并不是领卡的(不用new的方式获得内存),或者做了其他影响全局的操作,比如给门上画了涂鸦(如”绘图“)。这Java就头疼了,但是聪明的Java也有他的办法,Java允许他的客户有一个私人的小服务员finalize(),这个客户走的时候,就会招呼这个服务员,这个服务员就在房间里面等着,Java老板来了的时候,服务员就开始干房客交待的事情。同时大老板Java在自己的F-Queue队列小本上记上这个房间,先去回收没有服务员的房间去了,稍后再来看这个房间。诶,万一这个房客交待服务员finalize()做的事情,是把房间送给其他的房客(重新与引用链上的对象建立关联),那我们就不能回收了对吧,一个房间就“起死回生”,Java会把它从本本上划去。
看到这里,可以做一个书面总结
- 使用对象需要内存,Java使用了自动的垃圾回收技术,回收由new创建的对象,同时Java语言只能用new初始化对象(注意是Java语言)
- 对象可能不被垃圾回收
- 垃圾回收、finalize()并不等于“析构”
- 垃圾回收只与内存有关。(只是为了腾开空间)
何时使用finalize()方法?
只在回收内存的时候使用,虽然Java会回收所有对象,但是C语言或者其他语言申请的内存空间,Java就束手无策,需要用finalize()方法。
另外,JAVA虚拟机只能保证finalize()方法的执行,但是并不能保证它的完成!(防止阻塞)
除此之外,你还可以?
利用finalize()方法判断当前对象是否能被终结,下面是例子
class Book{
boolean check=true;
protected void finalize(){
if(check)
System.out.println("Error:the check is true");
super.finalize();
}
}
在这个例子中,我们要求书在被删去的时候,check是true,这样不符合的就会打印出错误
这里还使用了super.finalize()方法,super是父类对象的引用,调用这个可以使基类的一些操作也能被执行。
垃圾回收器的初识
C++的内存就像院子,用完了,整个院子都会消失
而Java所有的对象都只能使用new来创建,全部存储在堆上。
这并不会影响Java的速度,因为Java的内存采用的类似传送机一样的结构,Java的堆指针只是简单地移动到未分配的区域,效率很高。同时,垃圾回收器在工作的时候,一面回收空间,一面使堆中对象紧凑排列,这使得Java的内存分配速度十分高速高效。
另外,根据上面谈到的Java回收内存的两种方式,指的是“停止-复制”和“标记清理”,这是Java垃圾回收的四种算法的一部分,其他的不做深度阐述。
让你第一次认识到Java的内存管理的更多相关文章
- Java的内存管理与内存泄露
作为Internet最流行的编程语言之一,Java现正非常流行.我们的网络应用程序就主要采用Java语言开发,大体上分为客户端.服务器和数据库三个层次.在进入测试过程中,我们发现有一个程序模块系统内存 ...
- Java自动内存管理机制学习(一):Java内存区域与内存溢出异常
备注:本文引用自<深入理解Java虚拟机第二版> 2.1 运行时数据区域 Java虚拟机在执行Java程序的过程中把它所管理的内存划分为若干个不同的数据区域.这些区域都有各自的用途,以及创 ...
- java jvm内存管理/gc策略/参数设置
1. JVM内存管理:深入垃圾收集器与内存分配策略 http://www.iteye.com/topic/802638 Java与C++之间有一堵由内存动态分配和垃圾收集技术所围成的高墙,墙外面的人想 ...
- Java虚拟机内存管理机制
自动内存管理机制 Java虚拟机(JVM)在执行Java程序过程中会把它所管理的内存划分为若干个不同的数据区域.这些区域都有各自的用途,以及创建和销毁的时间,有的区域随着虚拟机进程的启动而存在,有的区 ...
- java Hotspot 内存管理白皮书(中文翻译)
转自: http://my.oschina.net/u/568779/blog/166891 1引言 一个健壮的 Java™2平台,Standard Edition (J2SE™)拥有一个自动内存管理 ...
- [基础] C++与JAVA的内存管理
在内存管理上(总之一句话——以后C++工程,一定要用智能指针!) 1.同是new一个对象,C++一定得手动delete掉,而且得时刻记住能delete的最早时间(避免使用空指针).JAVA可以存活于作 ...
- java HotSpot 内存管理白皮书
原文见:http://www.open-open.com/lib/view/open1381034220705.html.查阅资料后,对原文做了补充. 文中关于JVM的介绍基于JDK1.6的Hotsp ...
- Java的内存管理机制之内存区域划分
各位,好久不见.先做个预告,由于最近主要在做Java服务端开发,最近一段时间会更新Java服务端开发相关的一些知识,包括但不限于一些读书笔记.框架的学习笔记.和最近一段时间的思考和沉淀.先从Java虚 ...
- java虚拟机内存管理
1. java虚拟机内存如下 2. 运行时数据区 内存图分析:
随机推荐
- django学习笔记 多文件上传
习惯了flask 再用django 还是不太习惯 好麻烦 配置文件也忒多了 不过还是要学的 之前只能一个一个文件长传,这次试试多个文件 不适用django的forms创建表单 直接在html中使用 ...
- [BUG]excel复制到input含有不可见内容(零宽字符)
现象 excel手机号复制到input框子, length长度和可见长度不一致. "176xxxx1115" 长度是 13 而不是 11. 原因 手机号前后被 excel 插入 ...
- HTML每日学习笔记(3)
7.17.2019 XHTML 1.XHTML与HTML的区别: XHTML 元素必须被正确地嵌套. XHTML 元素必须被关闭. 标签名必须用小写字母. XHTML 文档必须拥有根元素.(所有的 X ...
- Java多线程并发08——锁在Java中的应用
前两篇文章中,为各位带来了,锁的类型及锁在Java中的实现.接下来本文将为各位带来锁在Java中的应用相关知识.关注我的公众号「Java面典」了解更多 Java 相关知识点. 锁在Java中主要应用还 ...
- Flutter配置环境报错“PKIX path building failed: sun.security.provider.certpath.SunCertPathBuilderException: unable to find valid certification path to requested target”
背景:最近看了很多Flutter漂亮的项目,想要尝试一下.所有环境都搭建好之后,按照文档一步一步配置(抄袭),但始终报如下图错误. PKIX path building failed: sun.sec ...
- 2. weddriver的定位方法
一. find_element_by_****的方式 首页在网页上鼠标右键选择检查并点击,查看需要定位的元素. https://www.baidu.com 以百度为例 导入模块的: from sel ...
- AdFind
C++实现(未开源),用于查询域内信息 http://www.joeware.net/freetools/tools/adfind/index.htm 常用命令如下: 列出域控制器名称: AdFind ...
- win7系统下的Nodejs开发环境配置
此处不推荐使用msi安装包直接安装nodejs,我们应该知道它里面做了哪些事情,这样以后出问题的时候,可以更快速地定位问题点.另一方面,直接安装的情况,以后更新了版本的话会很麻烦,因为如果我们想体验新 ...
- hdu1226超级密码 bfs
题目链接:http://icpc.njust.edu.cn/Problem/Hdu/1226/ 题目大意是:寻找一个五百位之内的C进制密码,该密码是N的正整数倍,而且只能用给定的数构成密码,求这样的密 ...
- 动态规划-Maximum Subarray-Maximum Sum Circular Subarray
2020-02-18 20:57:58 一.Maximum Subarray 经典的动态规划问题. 问题描述: 问题求解: public int maxSubArray(int[] nums) { i ...