对java内存的理解

java中内存主要包含4块,即heap(堆内存)、stack(栈内存)、data segment(静态变量或是常量存放区)、codesegment(方法区)

堆内存中存放的是new出的对象,new出的对象只包含成员变量。 
栈内存中:存放的是局部成员变量。对于基本的数据类型存放的是基本变量的值,而对于对象变量,存放的是堆内存的地址。 
静态、常量区:存放的是静态变量(类变量)或是常量。 
方法区:存放的是对象的方法。因此即使new出多个对象也是只是存在一个方法。 


今天没事想深入理解一下java的内存分配问题,于是就开始查资料和看视频,java中主要有堆内存和栈内存,比如有一个对象,当我们声明一个对象的引用的时候其实在栈内存中分配了一个空间,然后new出一个对象,此时就会在堆内存中分配一个内存空间来存储这个对象所需要的真是空间,栈中的对象引用指向对堆中分配的new出来的内存区域,这其实好比c语言中的指针,只不过好像栈中的引用存的不是堆内存中的地址,有人说是地址的hash值,至于这个不必深究,只要明白通过这个引用可以找到堆中的那块内存就行,而java中的方法是在执行的过程中才会分配占用内存,并不会在new对象中直接占用内存,


还有就是成员变量分配的内存在栈中,在一个方法中new出一个对象,当方法执行完的时候,栈中的内存会自动回收,此时堆中对应的内存已经失去引用,也就是没有存在的意义,垃圾回收器在下次执行的时候就会自动回收堆中的垃圾。


还有就是类中的成员变量如果是非静态在分配内存的时候在堆中,他是跟随new对象一起在堆内存中,如果是静态的则在方法区中。

java中的内存泄露指的是无用的对象被一个长生命周期的对象保持引用,从而导致无法释放内存,堆中的内存也就无法释放,从而造成内存泄露的问题。

安卓中常见的就是在生命单例的时候需要传入context对象,当我们传入的是activity的引用的时候由于单例的生命周期和整个应用的生命周期一样长,从而导致activity的对象一直被引用,不能被回收,垃圾回收器自然不能回收堆中还有引用指向的那块内存,从而早晨内存泄露。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值