java 中的包括以下几大种的内存区域:1.寄存器    2.stack(栈)  3.heap(堆)  4.数据段  5.常量池

那么相应的内存区域中又存放什么东西(主要介绍 stack heap)?

栈:1.基本数据类型的值(4类8种); 2.类的实例(堆区对象的引用) 3.局部变量和形参 4.return xx;会在stack中存在一个临时内存

堆:1.new出来的对象 2.类的对象拥有的成员变量,但是他们存储在各自的堆中。类的成员变量在不通对象中各不相同,都有自己的存储空间。

栈(stack)与堆(heap)优劣势:

1. stack内存存储容量较小,但是存取速度比heap快很多!

存储在栈中的数据大小跟生命周期必须确定,失去机动性。但是stack中的数据具有共享性!

理解stack的共享性:

int a=3; a是基本类型变量,存储在stack中,占有一块空间,空间名称是a,里面的值是3;

此时定义 int b=3;b也存储在stack中,但是不会占用stack的内存空间,因为编译器会先查找在stack中是否存在值为3的空间地址,若存在,则3还有另一个空间名称即 b。

读到这里可能会有一个问题: 假如我把a进行重新赋值,a=4,这时候b=4? 理所当然不不会!!!

因为当对a=4时,编译器会在stack重新查找有没有存在值为4的空间地址,如果没有则会在stack重新开辟地址为4的空间。b此时还是保持不变,占用没有a所开辟的空间地址!

2. heap内存存储容量较大, 堆可以动态的分配内存,跟C++中差不多,但是C++中的内存是手动释放,而jVM中存在垃圾收集器会自动收走这些不在引用的数据。由于要运行new,所以存取速度低于stack!

下面代码:

 package com.Demo;

 class BirthDate {
private int day;
private int month;
private int year; public void setDay(int day) {
this.day = day;
} public void disPlay() {
System.out.println("Year "+ year +"month "+month+"Day "+day);
} public BirthDate(int _day,int _month,int _year) {
day=_day;
month=_month;
year=_year;
}
} public class test { public void change1(int i) {
i=1234;
} public void change2(BirthDate b) {
b=new BirthDate(22,2,2004);
} public void change3(BirthDate b) {
b.setDay(22);
} /*
* 详细分析内存 程序执行的过程
*/
public static void main(String[] args){
test t=new test();
int date=9;
BirthDate b1=new BirthDate(30,12,1995);
BirthDate b2=new BirthDate(23,8,1996);
t.change1(date);
t.change2(b1);
t.change3(b2);
} }

程序在内存中的运行过程:

马老师说过:弄清楚了内存就弄清了一切!

java 内存深度解析的更多相关文章

  1. JAVA内存溢出解析(转)

    JAVA内存溢出解析(转) 核心提示:原因有很多种,比如: 1.数据量过于庞大:死循环 :静态变量和静态方法过多:递归:无法确定是否被引用的对象: 2.虚拟机不回收内存(内存泄漏): 说白了就是程序运 ...

  2. ES 内存深度解析

    注: 本文主要针对ES 2.x. “该给ES分配多少内存?”  “JVM参数如何优化?“ “为何我的Heap占用这么高?” “为何经常有某个field的数据量超出内存限制的异常?“ “为何感觉上没多少 ...

  3. Java内存泄漏解析!

    前言: 内存管理是Java最重要的优势之一,你只需创建对象,Java垃圾收集器会自动负责分配和释放内存.但是,情况并不那么简单,因为在Java应用程序中经常发生内存泄漏. 本章会说明什么是内存泄漏,为 ...

  4. Java ThreadLocal深度解析

    首先,ThreadLocal 不是用来解决共享对象的多线程访问问题的,一般情况下,通过ThreadLocal.set() 到线程中的对象是该线程自己使用的对象,其他线程是不需要访问的,也访问不到的.各 ...

  5. java内存分配和String类型的深度解析

    [尊重原创文章出自:http://my.oschina.net/xiaohui249/blog/170013] 摘要 从整体上介绍java内存的概念.构成以及分配机制,在此基础上深度解析java中的S ...

  6. 【转】java内存分配和String类型的深度解析

    一.引题 在java语言的所有数据类型中,String类型是比较特殊的一种类型,同时也是面试的时候经常被问到的一个知识点,本文结合java内存分配深度分析关于String的许多令人迷惑的问题.下面是本 ...

  7. Java内存模型深度解析:final--转

    原文地址:http://www.codeceo.com/article/java-memory-6.html 与前面介绍的锁和Volatile相比较,对final域的读和写更像是普通的变量访问.对于f ...

  8. Java内存模型深度解析:volatile--转

    原文地址:http://www.codeceo.com/article/java-memory-4.html Volatile的特性 当我们声明共享变量为volatile后,对这个变量的读/写将会很特 ...

  9. Java内存模型深度解析:顺序一致性--转

    原文地址:http://www.codeceo.com/article/java-memory-3.html 数据竞争与顺序一致性保证 当程序未正确同步时,就会存在数据竞争.java内存模型规范对数据 ...

随机推荐

  1. JavaWeb跨域访问问题

    转载: http://blog.csdn.net/zjq_1314520/article/details/65449279 最后的解决方案如下: 在 tomcat 的 conf目录下找到 web.xm ...

  2. 修改centos的时间,解决时间比本地实际时间快了8小时

    1.vi /etc/sysconfig/clock #编辑文件ZONE="Asia/Shanghai"UTC=false #设置为false,硬件时钟不于utc时间一致ARC=fa ...

  3. 基于JavaScript判断浏览器到底是关闭还是刷新(超准确)

    这篇文章主要介绍了基于JavaScript判断浏览器到底是关闭还是刷新(超准确)的相关资料,需要的朋友可以参考下 本文是小编总结的一些核心内容,个人感觉对大家有所帮助,具体内容请看下文: 页面加载时只 ...

  4. create a cocos2d-x-3.0 project in Xcode

    STEP1: Open Terminal SETP2: Run setup.py SETP3: Run source /Users/your_user/.bash_profile( so that e ...

  5. MySQL---insert into select from

    INSERT INTO perf_week(node_id,perf_time,pm25,pm10,temp,humi) SELECT node_id,'2016-12-22 11:55:00' AS ...

  6. Floyd 和 bellman 算法

    Floyd-Warshall算法(Floyd-Warshall algorithm)是解决任意两点间的最短路径的一种算法,可以正确处理有向图或负权的最短路径问题,同时也被用于计算有向图的传递闭包. F ...

  7. Python中的yield和Generators(生成器)

    本文目的 解释yield关键字到底是什么,为什么它是有用的,以及如何来使用它. 协程与子例程 我们调用一个普通的Python函数时,一般是从函数的第一行代码开始执行,结束于return语句.异常或者函 ...

  8. Splash scroll_position 属性

    scroll_position属性用于控制页面上下或左右滚动,如下,表示控制页面向下滚动 400 像素值并返回结果图, function main(splash, args) assert(splas ...

  9. [Git] 解决 insufficient permission for adding an object to repository database

    [环境] OS: CentOS 6.5 Git: 1.7.1 [症状描述] Git 中心仓库路径 ~/project.git,克隆库路径 ~/project.clone,克隆库中包含一个文件 ~/pr ...

  10. sql语句建表,并且自增加主键

    sql语句建表,并且自增加主键 use [test] CREATE TABLE [dbo].[Table_4] ( [userid] [int] IDENTITY(1,1) NOT NULL, CON ...