• Java之内存泄漏


    内存泄漏是指不再被使用的对象或者变量一直被占据在内存中。

    理论上来说,Java是有GC垃圾回收机制的,也就是说,不再被使用的对象,会被GC自动回收掉,自动从内存中清除。

    但是,即使这样,Java也还是存在着内存泄漏的情况:

    1. 长生命周期的对象持有短生命周期对象的引用就很可能发生内存泄露。
    
    尽管短生命周期对象已经不再需要,但是因为长生命周期对象持有它的引用而导致不能被回收,这就是Java中内存泄露的发生场景,
    通俗地说,就是程序员可能创建了一个对象,以后一直不再使用这个对象,这个对象却一直被引用,即这个对象无用但是却无法被垃
    圾回收器回收的,这就是Java中可能出现内存泄露的情况,例如,缓存系统,我们加载了一个对象放在缓存中(例如放在一个全局map
    对象中),然后一直不再使用它,这个对象一直被缓存引用,但却不再被使用。
    
    检查java中的内存泄露,一定要让程序将各种分支情况都完整执行到程序结束,然后看某个对象是否被使用过,如果没有,则才能判定这个对象
    属于内存泄露。
    
    如果一个外部类的实例对象的方法返回了一个内部类的实例对象,这个内部类对象被长期引用了,即使那个外部类实例对象不再被使用,但由于
    内部类持久外部类的实例对象,这个外部类对象将不会被垃圾回收,这也会造成内存泄露。
    
    2. 当一个对象被存储进HashSet集合中以后,就不能修改这个对象中的那些参与计算哈希值的字段了,否则,对象修改后的哈希值与最初存储进
    HashSet集合中时的哈希值就不同了,在这种情况下,即使在contains方法使用该对象的当前引用作为的参数去HashSet集合中检索对象,也将
    返回找不到对象的结果,这也会导致无法从HashSet集合中单独删除当前对象,造成内存泄露
    

    原文链接:https://blog.csdn.net/qq_41033290/java/article/details/85265449

  • 相关阅读:
    dos常用命令
    组合封装知识点
    继承与派生知识点
    继承与派生
    面向对象知识点
    面向对象
    Day 84 DRF的分页和过滤
    Day80 使用第三方(腾讯云)短信验证码接口
    Day 79 xadmin后台管理/Git仓库
    Day 77 三大认证组件
  • 原文地址:https://www.cnblogs.com/ITHSZ/p/13383833.html
Copyright © 2020-2023  润新知