发现之前写的可读性不好,这次准备试试换风格,去掉长篇大论,觉得这个风格好的,麻烦点个赞啦

清理、JVM的妙处

大家以后都是程序员,假设你很不幸,需要自己交钱租房子。

你作为一个小穷人,租的房子到期了(万一是你跳槽去了其他地方,滑稽),房子就要还给房东。

在很久之前,**房东C++**是个好人,等着房客主动来还房子,然后再把房子租出去(析构)。

这里C++只是说在堆上分配内存,而不是栈,求C++大佬们放过!!对不起!

后来叫Java的也来做了房东,Java很有钱,他有一栋大楼的房子,Java会给所有的租客一个叫内存的卡(new操作):

  1. 在客户多的时候,定期给租期还没到的人发新卡分配住处
  2. 在客户少的时候,Java就会喊所有人以及他认识的租客(活对象、引用链)来前台,给他们的卡上做个标记,这时溜号的人就没有这个标记,然后Java会把没有这个标记的人的房间重置用来下次租。

上面两种方式就是C++中的析构(还房子)与**Java的内存管理方式——垃圾回收(GC)**中的两种方式“停止-复制”与“标记-清扫”。

但是,Java有一些客户,是从C++和其他房东那里,借用客户的关系挖来的,他们的房子并不是领卡的(不用new的方式获得内存),或者做了其他影响全局的操作,比如给门上画了涂鸦(如”绘图“)。这Java就头疼了,但是聪明的Java也有他的办法,Java允许他的客户有一个私人的小服务员finalize(),这个客户走的时候,就会招呼这个服务员,这个服务员就在房间里面等着,Java老板来了的时候,服务员就开始干房客交待的事情。同时大老板Java在自己的F-Queue队列小本上记上这个房间,先去回收没有服务员的房间去了,稍后再来看这个房间。诶,万一这个房客交待服务员finalize()做的事情,是把房间送给其他的房客(重新与引用链上的对象建立关联),那我们就不能回收了对吧,一个房间就“起死回生”,Java会把它从本本上划去

看到这里,可以做一个书面总结

  1. 使用对象需要内存,Java使用了自动的垃圾回收技术,回收由new创建的对象,同时Java语言只能用new初始化对象(注意是Java语言)
  2. 对象可能不被垃圾回收
  3. 垃圾回收、finalize()并不等于“析构”
  4. 垃圾回收只与内存有关。(只是为了腾开空间)

何时使用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的内存管理的更多相关文章

  1. Java的内存管理与内存泄露

    作为Internet最流行的编程语言之一,Java现正非常流行.我们的网络应用程序就主要采用Java语言开发,大体上分为客户端.服务器和数据库三个层次.在进入测试过程中,我们发现有一个程序模块系统内存 ...

  2. Java自动内存管理机制学习(一):Java内存区域与内存溢出异常

    备注:本文引用自<深入理解Java虚拟机第二版> 2.1 运行时数据区域 Java虚拟机在执行Java程序的过程中把它所管理的内存划分为若干个不同的数据区域.这些区域都有各自的用途,以及创 ...

  3. java jvm内存管理/gc策略/参数设置

    1. JVM内存管理:深入垃圾收集器与内存分配策略 http://www.iteye.com/topic/802638 Java与C++之间有一堵由内存动态分配和垃圾收集技术所围成的高墙,墙外面的人想 ...

  4. Java虚拟机内存管理机制

    自动内存管理机制 Java虚拟机(JVM)在执行Java程序过程中会把它所管理的内存划分为若干个不同的数据区域.这些区域都有各自的用途,以及创建和销毁的时间,有的区域随着虚拟机进程的启动而存在,有的区 ...

  5. java Hotspot 内存管理白皮书(中文翻译)

    转自: http://my.oschina.net/u/568779/blog/166891 1引言 一个健壮的 Java™2平台,Standard Edition (J2SE™)拥有一个自动内存管理 ...

  6. [基础] C++与JAVA的内存管理

    在内存管理上(总之一句话——以后C++工程,一定要用智能指针!) 1.同是new一个对象,C++一定得手动delete掉,而且得时刻记住能delete的最早时间(避免使用空指针).JAVA可以存活于作 ...

  7. java HotSpot 内存管理白皮书

    原文见:http://www.open-open.com/lib/view/open1381034220705.html.查阅资料后,对原文做了补充. 文中关于JVM的介绍基于JDK1.6的Hotsp ...

  8. Java的内存管理机制之内存区域划分

    各位,好久不见.先做个预告,由于最近主要在做Java服务端开发,最近一段时间会更新Java服务端开发相关的一些知识,包括但不限于一些读书笔记.框架的学习笔记.和最近一段时间的思考和沉淀.先从Java虚 ...

  9. java虚拟机内存管理

    1. java虚拟机内存如下 2. 运行时数据区 内存图分析:

随机推荐

  1. Navicat for MySQL12破解

    本文摘抄自:https://blog.csdn.net/zhangli0910/article/details/83785147,https://blog.csdn.net/mmake1994/art ...

  2. 如何优雅的把后台数据(通常是JSON)轻松渲染到html页面

    如何优雅的把后台数据(通常是JSON)轻松渲染到html页面 在我们做前后端分离的时候,都有遇到过一些看起卡很简答,确无从下手的问题把.比方说后台给了前端一个list集合,集合里面有很多学生,我们现在 ...

  3. seo搜索优化技巧02-seo问答推广怎么做?

    问答推广就是以用户的​‌‌角度去提问,这些问题内容就是用户搜索想要知道的.简单来说通过第三方平台站在用户的角度去帮助客户解答问题,同时附带自身的品牌和产品信息就是问答推广. 常见的问答平台有百度知道. ...

  4. 02 layui 下载和搭建环境

    Layui官方网站 官方网站:https://www.layui.com/ 下载地址:https://res.layui.com/static/download/layui/layui-v2.5.5. ...

  5. Java继承中构造器的调用原理

    Java的继承是比较重要的特性,也是比较容易出错的地方,下面这个例子将展示如果父类构造器中调用被子类重写的方法时会出现的情况: 首先是父类: public class test { void fun( ...

  6. C#桌面开发的未来WebWindow

    目录 WebWindow 源码 作者博客 基于Chromium的Edge 体验 体验方式一: 体验方式二: 遗留的问题 WebWindow WebWindow是跨平台的库. Web Window的当前 ...

  7. Git使用ssh公钥

    Git使用ssh公钥 一.  何谓公钥 1.很多服务器都是需要认证的,ssh认证是其中的一种.在客户端生成公钥,把生成的公钥添加到服务器,你以后连接服务器就不用每次都输入用户名和密码了. 2.很多gi ...

  8. ggplot2练习

    图源于电力电子课本65页——电容滤波的单相不可控整流电路. f<-function(w,d) { l<-w/sqrt(w^2+1)*exp(-atan(w)/w)*exp(-d/w) r& ...

  9. JAVAEE学习day05学习,数组

    容器及元素的概念 容器:是将多个数据存储到一起 元素:每个数据称为该容器的元素 数组的概念 数组:数组是长度固定,存储数据的容器,保证多个数据的类型要一致 数组定义格式及其描述 动态定义: 数据类型 ...

  10. 在ES批量插入数据超时时自动重试

    当我们使用ES批量插入数据的时候,一般会这样写代码: from elasticsearch import Elasticsearch,helpers es =Elasticsearch(hosts=[ ...