Java finalize以及Garbage Collection
Java的垃圾回收机制:
Java的垃圾回收并不等于C++中的析构。Java中,只有在程序濒临存储空间用完的那一刻,对象占用的空间才会释放。所以,在JAVA程序中,我们通常只考虑创建对象,而从不关心对象的清除。这个策略是恰当的,因为垃圾回收本身也有开销,要是不使用它,那就不用支付这部分开销了。
什么情况下我们需要finalize():
有了垃圾回收,我们一般不需要关心对象空间的释放,但在一些特殊的内存区域,需要我们手动清除。
特殊的内存区域是指在分配内存时,如果一个对象正在处理的是非Java 资源,比如,调用类似C的malloc( )函数,用它分配存储空间,而且除非调用了free( )函数,否则存储空间将不会得到释放,从而造成内存泄露。当然,free( )是C和C++中的函数,所以你需要在finalize( )中用本地方法调用它;又比如文件句柄或window 字符字体,这时你要确认在一个对象被撤消以前要保证这些资源被释放。
由于一旦垃圾回收器准备好释放对象占用的存储空间,将首先调用其 finalize( )方法,并且在下一次垃圾回收动作发生时,才会真正回收对象占用的内存。所以我们将手动清除的方法写在finalize()函数中。
protected void finalize( )
{
// finalization code here
}
其中,关键字protected是防止在该类之外定义的代码访问finalize()标识符。
有三种情况会调用finalize():
1.所有对象被Garbage Collection时自动调用,比如运行System.gc()的时候.
2.程序退出时为每个对象调用一次finalize方法。
3.显式的调用finalize方法
Java finalize以及Garbage Collection的更多相关文章
- [Java] 垃圾回收 ( Garbage Collection ) 的步骤演示
		关于 JVM 垃圾回收机制的基础内容,可参考上一篇博客 垃圾回收机制 ( Garbage Collection ) 简介 上一篇博客,介绍了堆的内存被分为三个部分:年轻代.老年代.永生代.这篇博文将演 ... 
- hive impala C++ Java垃圾回收  Garbage Collection GC
		hive impala impala 推荐每个节点内存 2^7~2^8GB Impala与Hive的比较 - 文章 - 伯乐在线 http://blog.jobbole.com/43233/ &l ... 
- 深入理解Java中的Garbage Collection
		前提 最近由于系统业务量比较大,从生产的GC日志(结合Pinpoint)来看,需要对部分系统进行GC调优.但是鉴于以往不是专门做这一块,但是一直都有零散的积累,这里做一个相对全面的总结.本文只针对Ho ... 
- Java Garbage Collection Basics--转载
		原文地址:http://www.oracle.com/webfolder/technetwork/tutorials/obe/java/gc01/index.html Overview Purpose ... 
- Java垃圾回收机制(Garbage Collection)
		引用博客地址:http://www.cnblogs.com/ywl925/p/3925637.html 以下两篇博客综合描述Java垃圾回收机制 第一篇:说的比较多,但是不详细 http://www. ... 
- [翻译]Java垃圾收集精粹(Java Garbage Collection Distilled)
		source URL: http://www.infoq.com/articles/Java_Garbage_Collection_Distilled Name: Java Garbage Colle ... 
- [Java] 垃圾回收机制 ( Garbage Collection ) 简介
		自动垃圾回收( Automatic Garbage Collection ) 自动垃圾回收,是指在堆(Heap)内存上分辨哪些对象还在被使用,哪些对象没有被使用,并清除没有被使用的对象.所以,这里的垃 ... 
- JVM垃圾收集(Java Garbage Collection / Java GC)
		JVM垃圾收集(Java Garbage Collection / Java GC) Java7 Java8 JDK1.8之后将最初的永久代取消了,由元空间取代. 堆内存调优简介 public sta ... 
- Garbage Collection Optimization for High-Throughput and Low-Latency Java Applications--转载
		原文地址:https://engineering.linkedin.com/garbage-collection/garbage-collection-optimization-high-throug ... 
随机推荐
- Linux性能分析 vmstat输出
			vmstat输出 1.linux系统下vmstat输出 vmstat的输出分为以下几种模式: (1).VM MODE (普通选项) (2).DISK MODE(-d选项) (3).DI ... 
- web项目除了业务还需要关注的点
			1:安全性,不允许访问外网,访问外网通过反向代理的方式. 2:安全性,和外网交互的时候,需要CA证书,基于SSL协议的证书 3:日志,生产上通常会关闭某些日志,所以,允许出现的日志就显得至关重要了. ... 
- 第12章 网络基础(2)_数据封装和IP地址
			4. 数据封装和IP地址 (1)数据封装 (2)IP地址 ①在TCP/IP网络中,每个主机都有唯一的地址,它是通过IP协议族实现的. ②IP协议要求在每次与TCP/IP网络建立连接时,每台主机都必须为 ... 
- nodejs中https请求失败,无报错
			今天群里一位同学在做练习的时候,采用https例子: // curl -k https://localhost:8000/ const https = require('https'); const ... 
- 序列化  ,hashlib  ,configparser ,logging  ,collections模块
			# 实例化 归一化 初始化 序列化 # 列表 元组 字符串# 字符串# .......得到一个字符串的结果 过程就叫序列化# 字典 / 列表 / 数字 /对象 -序列化->字符串# 为什么要序列 ... 
- Python面向对象之内置方法
			1.isinstance(obj,cls)和issubclass(sub,super) isinstance(obj,cls)检查是否obj是否是类 cls 的对象 issubclass(sub, s ... 
- tensorflow data's save and load
			note: if you'll load data,the data shape should be similar with saved data's shape. -- 中式英语,天下无敌 ... 
- convolution-卷积神经网络
			训练mnist数据集 结构组成: input_image --> convolution1 --> pool1 --> convolution2 --> pool2 --> ... 
- cplexJava源码---计算结果
			public static class CplexStatus implements Serializable { static final long serialVersionUID = -7367 ... 
- uva-10004-俩色图验证
			题意: 在1976年,四色猜想被一个计算机助手提出,这个理论表示对任意一个地图的上色都只需要四种颜色,地图内每一个区块和相邻的区块颜色都不相同.你现在被要求解决一个相似但相对简单的问题.给你任意一个连 ... 
