首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

为什么onDestroyView()不释放我的内存

onDestroyView()方法是Fragment生命周期中的一个回调方法,它在Fragment的视图被销毁时调用。该方法主要用于释放与Fragment视图相关的资源,但并不负责释放Fragment所占用的内存。

在Android中,内存的释放是由垃圾回收器(Garbage Collector)负责的。垃圾回收器会自动检测不再被引用的对象,并将其回收释放内存。当Fragment的视图被销毁时,系统会自动处理相关的内存释放工作,包括回收Fragment视图所占用的内存。

然而,如果在Fragment中存在其他引用对象(如Context、Bitmap等),这些对象可能会导致内存泄漏。内存泄漏指的是应该被回收的对象仍然被引用,导致无法释放内存。在onDestroyView()方法中,可以通过手动释放这些引用对象来避免内存泄漏。

总结起来,onDestroyView()方法主要用于释放与Fragment视图相关的资源,但并不直接负责释放Fragment所占用的内存。要避免内存泄漏,需要在onDestroyView()方法中手动释放其他引用对象。

页面内容是否对你有帮助?
有帮助
没帮助

相关·内容

MySQL 删除数据不释放内存

DELETE 不释放磁盘空间 delete from table_name 原因 使用delete删除的时候,MySQL并没有把数据文件删除,只会将已经删除的数据标记为删除,因此并不会彻底的释放空间。...这些被删除的数据会被保存在一个链接清单中,当有新数据写入的时候,MySQL会利用这些已删除的空间再写入。 删除操作会带来一些数据碎片,正是这些碎片在占用硬盘空间。这些被标记为删除的记录,就是数据空洞。...删除数据释放内存方式 1、使用 drop 或 truncate drop table table_name; truncate table table_name; 2、OPTIMIZE optimize...使用OPTIMIZE TABLE来重新利用未使用的空间,并重新整理数据文件的碎片。 减少表数据与表索引的物理空间,降低访问表时的 IO。在OPTIMIZE TABLE运行过程中,MySQL会锁定表。...导出表语法 mysqldump -u用户名 -p密码 -h主机 数据库 表 -- 例如 mysqldump -uroot -p sqlhk9 a --no-data 注意:这种方式会影响业务正常使用,不推荐

61810

内存占用过高,缓存不释放导致死机处理方案

故障现象: 1、某分行部署的某台服务器内存占用过高,导致死机; 2、代码层面检查暂未发现问题,服务器硬重启持续一段时间后(3-5天)再次占满。...发现问题: 赶往现场后进行检查,当时是一切正常的,今有DB2进程占用18%,在正常范围内; 在crontab 中发现有两个脚本每天14点进行FTP批量数据传输,找到相应的传输文件存放目录发现每天传输的文件达到...30多个G,由此可判断这就是故障之根本,FTP传输文件,会缓存到内存中,服务器内存也只有32G,FTP传输导致缓存被占满,Linux不能自动清理缓存导致死机。...Linux内存中缓存占用的空间是可以自动释放的,现在缓存占用了整个内存导致死机,肯定是没有自动释放缓存。 解决方法: 设定Linux内存参数,始终留出一块空间,以避免缓存不释放导致死机。...方案一: 可手动清理页文件缓存,但是需手动执行; echo 1 > /pron/sys/vm/drop_caches 方案二: 我们采用的方法是设定内存最低剩余内存,不让缓存占满 1.使用root

4.6K30
  • 为什么我不建议你用 Select * ?

    作者:AIOps 应用程序慢如牛,原因多多,可能是网络的原因、可能是系统架构的原因,还有可能是数据库的原因。 那么如何提高数据库SQL语句执行速度呢?...有人会说性能调优是数据库管理员(DBA)的事,然而性能调优跟程序员们也有莫大的关系。 程序中嵌入的一行行的SQL语句,如果使用了一些优化小技巧,定能达到事半功倍的效果。...技巧3 为列选择合适的数据类型 能用TINYINT就不用SMALLINT,能用SMALLINT就不用INT,道理你懂的,磁盘和内存消耗越小越好嘛。...然而,为了达到更好的性能以及更好的数据控制,你可以将他们变成多个小查询。 ?...技巧10 ORDER BY 的列尽量被索引 ORDER BY的列如果被索引,性能也会更好。 技巧11 使用 LIMIT 实现分页逻辑 不仅提高了性能,同时减少了不必要的数据库和应用间的网络传输。

    1.7K20

    为什么我不建议你写注释?

    注释的恰当用法是弥补我们在用代码表达意图时遭遇的失败,我用了失败一词,其实是说真的。注释总是一种失败,是因为我们无法找到不用注释就能表达这段代码含义的方法。...并不是不让你真的不用注释,而是有些时候,用注释是因为我们怕其他的开发者在我们的代码的时候,看不懂我们的代码从而去加注释,那么我们为什么不写出其他开发者一目了然的代码呢?...为什么不建议写注释? 为什么我们极力贬低注释?因为注释跟代码一样,注释会撒谎,但这并不是我们有意的写一些撒谎的注释。...我们可以想象一个项目如果做了一年两年三年,代码的业务逻辑永远都不会改变吗?不可能……. 注释存在的时间越久,就离其所之前描述的代码越远,越来越久就会变得全然错误。为什么呢?...带有少量注释的整洁而有表达力的代码,比带有大量注释的零碎而又复杂的代码像样的多,与其花时间编写解释你写的代码的注释,倒不如花时间清洁你那堆糟糕的代码。 如何用代码来阐述? 你愿意看到这个?

    1.2K20

    出大事了,涛哥你们Java应用GC后不释放内存

    前言 公司众多系统中有一个系统使用的是 CMS 垃圾回收器,JVM 初始堆内存不等于最大堆内存,但通过监控信息发现:在经过一次 FullGC 之后,服务器物理内存剩余空间并未提升,运维同事告诉我说,有内存泄露...,因为 GC 了之后,内存并没有被释放。...按照大部分人的理解,FullGC 之后 JVM 进程会释放的内存一部分还给物理内存,下面通过几个实验来对比验证一下 CMS 和 G1 的物理内存归还机制。...小结 如果代码保持不变,但是JVM参数中设置Xms和Xmx相同的话,不管是否有FullGC,堆内存大小都不发生变化,也就不释放内存给操作系统 GC 后如何归还内存给操作系统: 能不能归还,主要依赖于 Xms...YGC 是不能使 JVM 主动归还内存给操作系统的。 尽量保持 Xms 和 Xmx 一致,这样可以减少堆内存调整带来的性能损耗,也可以减少堆内存调整带来的无内存风险。

    5.5K11

    为什么我的自动化流程不执行

    很多人经常会有这个问题,为什么我的自动化流程不执行。...如果你设置好了自动化流程,但是自动化流程却没有执行,请按照如下的顺序检查你的流程配置:第一步:请检查自动化流程有没有发布和上线来到【操作后台】- 【我的流程】,上线的流程会如图显示【上线】;没有上线的流程会显示灰色...我的流程第二步:请检查自动化流程是否有执行请来到后台【流程日志】,如果运行成功的流程就会显示【执行成功】并有一个【运行id】。...自动化流程执行失败第三步:确认流程是上线状态,但是流程没有执行,为什么?如果流程确认是上线状态,需要确定你的流程是否符合你设定的触发条件,如果没有达到对应的条件,是不会触发的。...,被判断了没有执行【流程执行过程中修改】:在有【延迟执行】的流程上线后,进行修改,会导致后续的流程不执行

    1.5K30

    我为什么不建议使用框架默认的 DefaultMeterObservationHandler

    我为什么不建议使用框架默认的 DefaultMeterObservationHandler 背景知识 最近,我们升级了 SpringBoot 3.x,并且,升级后,我们全面改造了原来的 Sleuth 以及...导致),刚开始我们因为 CPU 飙高是内存溢出引起的,但是后来发现,并不只这个原因。...,但是仅仅因为 Observation 的创建和 start,就导致内存溢出,这是不合理的,我们分析一下,为何会出现这个问题。...为何会出现内存溢出 我们通过增加如下启动参数启动并且在退出的时候 dump JFR: -XX:StartFlightRecording=disk=true,dumponexit=true 或者使用下面的参数在内存溢出的时候...我们将全局的 ObservationHandler 改为什么都不做的,对比下: package com.github.hashjang.wwsmbjysymrdo; import io.micrometer.common.KeyValue

    13600

    如何释放Python占用的内存?

    这也是为什么我们称Python语言为动态类型的原因(这里我们把动态类型可以简单的归结为对变量内存地址的分配是在运行时自动判断变量类型并对变量进行赋值)。...对于C语言来讲,我们创建一个变量A时就会为为该变量申请一个内存空间,并将变量值 放入该空间中,当将该变量赋给另一变量B时,会为B申请一个新的内存空间,并将变量值放入到B的内存空间中,这也是为什么A和B的指针不一致的原因...再加上频繁的分配与释放小块的内存会产生内存碎片....,我猜想是python进行了优化,虽执行了,但是并没有分配。...想着不kill进程的情况下全部释放内存,这个暂时没有办法处理。后面找到办法再续。

    2.1K10

    为什么我不建议你用 if-else ?

    来源:codenong.com/cs106475567 为什么我们写的代码都是 if-else?...可以看到,最初的版本 if-else 最深的嵌套有三层,看上去逻辑分支非常多,进到里面基本都要被绕晕。其实,仔细想想嵌套内的 if-else 和最外层并没有关联性的,完全可以提取最顶层。...原来的做法先赋值给 result 最后统一 return,那么对于最后 return 的值到底是那个函数返回的结果不明确,增加了一层理解难度。...函数的好处是屏蔽内部实现,缩短 if-else 分支的代码。代码结构和逻辑上清晰,能一下看出来每一个条件内做的功能。...状态处理型重构方法实例二 针对状态处理的代码,一种优雅的做法是用多态取代条件表达式(《重构》推荐做法)。 你手上有个条件表达式,它根据对象类型的不同而选择不同的行为。

    2.1K20

    为什么我不建议自研BI系统?

    互联网的本质之一是信息共享,而共享的背后是各种原子粒度的数据流动。有以内容生产和内容消费匹配为目的的数据流动,比如搜索引擎;也有以人、货、场信息匹配为目的的数据流动,比如电商平台。...业务需求:如果数据是用于支持企业的核心业务发展,且业务复杂度比较高,或者业务的拓展和迭代非常快,因而对BI系统的定制化程度和未来的可拓展能力有着更高的要求,这时需要评估市面上的第三方系统是否可以满足。...成本层面: 人力成本:自研需要企业组建专门的团队,投入一定的开发资源,程序员的工资是明面上要计算的帐。...先前我们了解过一家互联网+金融的企业,因为基金交易的属性决定了他们对数据的需求是非常强烈的,对数据分析的复杂度和数据安全性的要求也更高。...所以在不考虑未来商业化的前提下,如果第三方厂商所提供的产品能满足现阶段对BI的需求,那外采是比较经济的选择。 另一种是数据和业务需求的复杂度比较低,但企业有意愿也有能力投入较多的资源。

    75920

    单机单节点 MongoDB 为什么删除数据后不释放空间?

    MongoDB3.6 以后,默认使用的储存引擎是 WiredTiger。这个引擎有一个特点,就是删除数据不释放空间。例如现在你的一个集合里面有 10000000 条数据,占用 10GB 的硬盘空间。...你把其中的 9999999 条数据都删了,占用空间仍然是 10GB。 如果你想释放空间,最直接的方法是删除整个集合(Drop Collection)或者删除整个数据库(Drop Database)。...如果你的 MongoDB 版本小于 4.4,但是大于等于 3.6,那么虽然删除了数据,磁盘空间不会释放,但当你插入新的数据时,MongoDB 会重用之前占有的空间,而不会继续额外占用新的磁盘空间。...这里显示的数据就是当前集合可重用的空间大小。如下图所示。...如果你的 MongoDB 允许暂停读写操作,那么还可以在 Robo 3T 或者 Mongo Shell 中使用 compact 命令来释放空间。

    2.5K30

    【C++】动态内存管理 ④ ( 对象的动态创建和释放引申思考 | 基础数据类型 内存分析 | malloc 分配内存 delete 释放 | new 分配内存 free 释放内存 )

    malloc 分配的内存 , 需要使用 free 进行释放 ; 使用 new 分配的内存 , 需要使用 delete 进行释放 ; 那么 使用 malloc 申请的内存 , 是否能使用 delete 进行释放..., 使用 new 申请的内存 , 是否能使用 free 进行释放 , 下面分为不同类型的数据申请内存的几种情况进行讨论 : 为基础数据类型分配内存 为数组数据类型数据分配内存 为类对象分配内存 二、基础数据类型...内存分析 1、malloc 分配内存 delete 释放内存 使用 malloc 函数 为 基础类型 分配的内存 , 可以使用 delete 进行释放 ; 在下面的代码中 , 使用 malloc 函数..., 说明对于 使用 malloc 函数 为 基础类型 申请的 堆内存空间 , 使用 delete 操作符 可以完成 free 函数的职能 , 成功释放内存空间 ; // malloc 申请的内存 使用..., 说明对于 使用 malloc 函数 为 基础类型 申请的 堆内存空间 , 使用 delete 操作符 可以完成 free 函数的职能 , 成功释放内存空间 ; // malloc 申请的内存 使用

    38830

    Lua模块的加载与内存释放

    今天早上听说一件事情让我觉得很诡异的事情:公司线上的一款游戏,加载一份配置资源后,内存涨了几十M,然后内存再也下不来了。...因为好奇,所以要来了最大的一个配置文件(4.5M,去除空格与换行后的大小),进行测试。最终发现,内存其实是可以被释放的,不过需要注意以下的规则。...进入下载好的 luajit 解压目录 LuaJIT-2.1.0-beta2/src  运行 msvcbuild.bat 重点在模块的编写,模块编写的方法导致了释放内存的不同。...我拿到的 lua 文件是这样定义的,原本是一个json,将其转为lua的,将所有数据赋值给一个变量(require 之后多了一个全局变量),这样 package.loaded[modulename] 为...一个约4.5M的 lua 文件,被 require 进内存后,lua 所占用的内存大小变为 20M。为什么会这么大,有待进一步从源码中寻找答案。

    2.9K30

    我为什么不建议你使用Python3.7.3?

    作者: Lateautumn4lin 来源:云爬虫技术研究笔记 ---- 之前使用Python的环境一直是Python3.7.3的,一直使用的很正常,没有什么毛病,直到最近做一个图片下载器的时候发现了问题...SSL证书,不过我这里的问题是使用的是Aiohttp库,并没有Verify这个参数,所以我们并不能使用这个去忽略这个问题。...解决一下 Goole了一下,发现其实不止我一个人出现了这个问题,已经有老哥在Aiohttp的Issue里面提了相关的问题了,可以参考https://github.com/aio-libs/aiohttp...可惜我的环境之前是3.7.3 我们知道了问题的解决办法,我们再去看看为什么会有这个问题?...把关于OSError的错误完全捕获住,避免造成错误的遗漏。

    2.1K30

    Java直接内存分配和释放的讲解

    前言 直接内存是分配在JVM堆外的,那JVM是怎么对它进行管理的呢?本文主要介绍一下在Java中,直接内存的空间分配和释放的机制。 直接内存和堆内存的比较 在比较两者的性能时,我们分两方面来说。...但直接内存在IO读写上的性能要优于堆内存,所以直接内存特别适合申请以后进行多次读写。 为什么在申请空间时,堆内存会更快?...堆内存的申请是直接从已分配的堆空间中取一块出来使用,不经过内存申请系统调用,而直接内存的申请则需要本地方法通过系统调用完成。 而为什么在IO读写时,直接内存比较快?因为直接内存使用的是零拷贝技术。...直接内存的最大大小可以通过-XX:MaxDirectMemorySize来设置,默认是64M 直接内存的分配和释放 在Java中,分配直接内存有三种方式: Unsafe.allocateMemory()...它分配内存和释放内存是通过一下方法来实现的。

    83240

    Python 为什么没有 main 函数?为什么我不推荐写 main 函数?

    对于这些“知情人”,他们有一定的道理。 但是,我个人并不推荐这种写法,甚至有时候会非常反感!...为什么要写那行 if 语句呢?可能的话,应该拆分 main 函数,甚至不必封装成一个函数啊! 我个人总结出以下的经验: 打破惯性思维,写出地道的代码。...首先,如果只有一个文件的话,因为不存在导出的可能,不建议写。...最后,多文件的非入口文件也不建议写,因为在非入口文件中写这个判断,最大的作用就是写一些测试代码,但是测试代码应该分离出来,写到专门的目录或文件中。...小结:本文首先解释了什么是 main 入口函数,以及为什么某些语言会强制要求写 main 函数;接着,解释了为什么 Python 不需要写 main 函数;最后则是针对某些人存在的惯性误区,分享了我个人的四点编程经验

    2.5K31

    Java的内存释放机制:垃圾回收详解

    Java作为一种面向对象的编程语言,具有自动内存管理的特性,即垃圾回收(Garbage Collection)。这一机制使得开发者不必手动管理内存,有效地减少了内存泄漏的风险。...本文将深入探讨Java的内存释放机制,解释垃圾回收的工作原理以及一些优化策略。 1. 垃圾回收概述 垃圾回收是Java虚拟机(JVM)的一项核心功能,负责自动识别和释放不再被程序引用的内存对象。...这些不再使用的对象称为"垃圾",而垃圾回收器负责在程序运行时定期清理这些垃圾,释放内存资源。 2....垃圾回收(Garbage Collection): 不可达对象被垃圾回收器识别并释放。 2.2 垃圾回收算法 Java的垃圾回收器使用不同的算法来识别和清理不再使用的对象。...希望本文能够为你提供清晰的指导,让你更好地理解和利用Java的内存释放机制。Happy coding! 收藏 | 0点赞 | 0打赏

    77310

    C# 快速释放内存的大数组

    本文告诉大家如何使用 Marshal 做出可以快速释放内存的大数组。 最近在做 3D ,需要不断申请一段大内存数组,然后就释放他,但是 C# 对于大内存不是立刻释放,所以就存在一定的性能问题。...在博客园看到了一位大神使用 Marshal 做出快速申请的大数组,于是我就学他的方法来弄一个。本文告诉大家这个类是如何使用。 在使用的时候,先来看下原来的 C# 的大数组性能。...那么遍历的时候什么输出一些诡异的值,实际上因为没有初始化,里面的值是不确定的。我觉得用这个做随机数也不错。...释放内存 那么如何释放内存?因为这个申请是没有经过管理的,如果没有手动释放,那么就出现内存泄露。...上面的方法暂时不告诉大家如何做,因为涉及到公司的使用。 ----

    3K20

    为什么我不建议你通过 Python 去找工作?

    意识到自己的问题之后,我就赶紧给读者“前进一点”发了一条信息道歉。另外,回想起之前还有一些读者问过我类似的问题,我的答案都不够严谨,因此打算特意写一篇文章来反省一下。...01、人工智能和机器学习人工智能和机器学习是 Python 应用的重头戏,但这方面的岗位对学历的要求非常高,高到我自己都应聘不上,非常残酷。...考虑到我的读者已经蔓延到了初中生群体,我得郑重其事地说一句,“如果你喜欢学习,那就好好学,别在该学习的年纪浪费了青春。”哎呀,我去,说这句话真有点拿自己做反面教材的感觉。...03、爬虫关于爬虫,不得不提一下羊哥视频评论区的一句话,不管是不是段子,我觉得挺值得深思的。 我有个同学搞爬虫被带走了,还好他不是主犯,就是登记了一下。...拿我来说吧,我希望自己的文章只发表在我希望发表的平台下,假如其他平台在未经我的授权下,就把我的文章爬走,放在自家平台上,我就觉得知识产权受到了破坏。

    2.8K20
    领券