当前位置:首页 > 文章列表 > Golang > Go问答 > Go GC 似乎没有收集我用于图像加载的未引用指针?

Go GC 似乎没有收集我用于图像加载的未引用指针?

来源:stackoverflow 2024-04-10 23:18:32 0浏览 收藏

大家好,今天本人给大家带来文章《Go GC 似乎没有收集我用于图像加载的未引用指针?》,文中内容主要涉及到,如果你对Golang方面的知识点感兴趣,那就请各位朋友继续看下去吧~希望能真正帮到你们,谢谢!

问题内容

我正在使用 OpenGL 开发一个 Go 项目,并且有代码可以通过 go/image 库加载图像文件。该函数没有留下永久指针,然后我离开该函数的范围。我希望该内存在下一个 GC 周期中被清除,但似乎并没有。我希望更了解 go 的人可以帮助我了解为什么图像没有被清除。

代码要点:https://gist.github.com/gjh33/62a75ccde6a7d849311804d31d7ee9ff

不调用该方法时,内存占用为17mb,调用该方法时,内存占用为40mb。即使等待 5 分钟后,该内存也不会被 GC。

如果您没有在 go 中使用过 openGL,请记住一些事情:

  • 到不安全指针的转换(第 41 行)通过以下方式进行:https://github.com/go-gl/gl/blob/master/v3.2-core/gl/conversions.go
  • 我正在使用 go-gl v3.2-core
  • 如果您需要更多信息或背景信息,请直接询问

解决方案


这是一个主要的误解:Go 是一种垃圾收集语言,这意味着内存仅在所谓的垃圾收集期间被释放,垃圾收集定期 并且不会以任何方式由正在执行的代码中超出范围的变量触发。

可以说,在 Go 实现的 GC 算法中,每次扫描都由两个连续的阶段组成:扫描和清除。 在扫描阶段,将遍历所有活动对象(通过它们相互维护的指针(如果有的话),并且通过正在运行的 goroutine 和全局变量的堆栈无法访问的对象被标记为在扫描阶段发生的释放。

Go 运行时实现了一个相当复杂的“估计器”,它试图推断启动下一个 GC 会话的目标堆大小,以便在堆使用率和支付的 CPU 成本之间取得平衡用于执行 GC 会话。

这意味着两件事:

  • 在 Go 中,丢失对已分配内存块的所有引用这一事实对于运行时来说没有任何意义:这个事实只会在下一个 GC 周期中被考虑。
  • 在不执行任何分配的空闲程序中,一块已分配的内存有可能根本不会被回收,因为永远不会执行 GC 循环。

附带说明一下,GC 的原始图像 您所持有的作品本身并不是不真实的 - 确实存在没有显式内存管理的编程语言,在您提到的情况下,它们实际上会取消分配内存。这对于脚本(至少最初)编程语言来说是典型的,例如 Python、Tcl、Perl(至少 5)等。这些语言对它们操作的使用所谓的引用计数。逻辑基本上是,每次对变量进行赋值(包括将其作为函数的参数传递)都会增加为该变量记录的引用数量,并且当执行离开变量的范围时,保存在变量中的值的引用计数它被减少。当某个值的引用计数降至 0 时,该值将被释放。

这种方法有效,而且看起来很自然,但它有一些缺点,例如:

  • 需要为每个值维护一个引用计数字段。
  • 每次更新该字段时都需要花费 CPU 周期(此外还有 CPU 缓存抖动)。
  • 该方案无法处理循环引用。

我还要补充一点,该方案不能很好地处理对变量的并发访问:如果您在混合中添加并发(如 Go 中),您最终将需要这些引用计数的所有更新字段是互斥的,并且会出现一些不有趣的问题,例如当一个执行线程取消引用一个值,注意到引用计数越过零并释放该值,然后另一个线程等待前者增加引用时,如何处理这种情况解除阻塞后发现它想要引用的值已经不存在了。

本篇关于《Go GC 似乎没有收集我用于图像加载的未引用指针?》的介绍就到此结束啦,但是学无止境,想要了解学习更多关于Golang的相关知识,请关注golang学习网公众号!

版本声明
本文转载于:stackoverflow 如有侵犯,请联系study_golang@163.com删除
如何将定义为字符串的类型与字符串进行比较如何将定义为字符串的类型与字符串进行比较
上一篇
如何将定义为字符串的类型与字符串进行比较
WIN8设置本地ip地址的操作方法
下一篇
WIN8设置本地ip地址的操作方法
查看更多
最新文章
查看更多
课程推荐
  • 前端进阶之JavaScript设计模式
    前端进阶之JavaScript设计模式
    设计模式是开发人员在软件开发过程中面临一般问题时的解决方案,代表了最佳的实践。本课程的主打内容包括JS常见设计模式以及具体应用场景,打造一站式知识长龙服务,适合有JS基础的同学学习。
    542次学习
  • GO语言核心编程课程
    GO语言核心编程课程
    本课程采用真实案例,全面具体可落地,从理论到实践,一步一步将GO核心编程技术、编程思想、底层实现融会贯通,使学习者贴近时代脉搏,做IT互联网时代的弄潮儿。
    511次学习
  • 简单聊聊mysql8与网络通信
    简单聊聊mysql8与网络通信
    如有问题加微信:Le-studyg;在课程中,我们将首先介绍MySQL8的新特性,包括性能优化、安全增强、新数据类型等,帮助学生快速熟悉MySQL8的最新功能。接着,我们将深入解析MySQL的网络通信机制,包括协议、连接管理、数据传输等,让
    498次学习
  • JavaScript正则表达式基础与实战
    JavaScript正则表达式基础与实战
    在任何一门编程语言中,正则表达式,都是一项重要的知识,它提供了高效的字符串匹配与捕获机制,可以极大的简化程序设计。
    487次学习
  • 从零制作响应式网站—Grid布局
    从零制作响应式网站—Grid布局
    本系列教程将展示从零制作一个假想的网络科技公司官网,分为导航,轮播,关于我们,成功案例,服务流程,团队介绍,数据部分,公司动态,底部信息等内容区块。网站整体采用CSSGrid布局,支持响应式,有流畅过渡和展现动画。
    484次学习
查看更多
AI推荐
  • 千音漫语:智能声音创作助手,AI配音、音视频翻译一站搞定!
    千音漫语
    千音漫语,北京熠声科技倾力打造的智能声音创作助手,提供AI配音、音视频翻译、语音识别、声音克隆等强大功能,助力有声书制作、视频创作、教育培训等领域,官网:https://qianyin123.com
    193次使用
  • MiniWork:智能高效AI工具平台,一站式工作学习效率解决方案
    MiniWork
    MiniWork是一款智能高效的AI工具平台,专为提升工作与学习效率而设计。整合文本处理、图像生成、营销策划及运营管理等多元AI工具,提供精准智能解决方案,让复杂工作简单高效。
    193次使用
  • NoCode (nocode.cn):零代码构建应用、网站、管理系统,降低开发门槛
    NoCode
    NoCode (nocode.cn)是领先的无代码开发平台,通过拖放、AI对话等简单操作,助您快速创建各类应用、网站与管理系统。无需编程知识,轻松实现个人生活、商业经营、企业管理多场景需求,大幅降低开发门槛,高效低成本。
    191次使用
  • 达医智影:阿里巴巴达摩院医疗AI影像早筛平台,CT一扫多筛癌症急慢病
    达医智影
    达医智影,阿里巴巴达摩院医疗AI创新力作。全球率先利用平扫CT实现“一扫多筛”,仅一次CT扫描即可高效识别多种癌症、急症及慢病,为疾病早期发现提供智能、精准的AI影像早筛解决方案。
    198次使用
  • 智慧芽Eureka:更懂技术创新的AI Agent平台,助力研发效率飞跃
    智慧芽Eureka
    智慧芽Eureka,专为技术创新打造的AI Agent平台。深度理解专利、研发、生物医药、材料、科创等复杂场景,通过专家级AI Agent精准执行任务,智能化工作流解放70%生产力,让您专注核心创新。
    214次使用
微信登录更方便
  • 密码登录
  • 注册账号
登录即同意 用户协议隐私政策
返回登录
  • 重置密码