关于Heap free block xxxxxxxx modified at xxxxxxxxx after is was freed

关于Heap free block xxxxxxxx modified at xxxxxxxxx after is was freed程序崩溃了,日志中的提示是:Heapfreeblockxxxxxxxxmodifiedatxxxxxxxxxafteriswasfreed和百度快乐地玩耍了很久,得知造成这种错误的原因可能是野指针,即指针指向的内存位置不是你想要的东西,它很可能已经被删除或者移动了。事情是这样发生的:我在逻辑中使用了三个List(AllSpriteList,FriendList,Enemy

大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。

Jetbrains全系列IDE使用 1年只要46元 售后保障 童叟无欺

程序崩溃了,日志中的提示是:Heap free block xxxxxxxxmodified at xxxxxxxxx after is was freed

和百度快乐地玩耍了很久,得知造成这种错误的原因可能是野指针,即指针指向的内存位置不是你想要的东西,它很可能已经被删除或者移动了。

事情是这样发生的:我在逻辑中使用了三个List(AllSpriteList,FriendList,EnemyList)来管理战场上所有的精灵,这三个List分别装着所有精灵、我方精灵和敌方精灵。

我让AllSpriteList进入游戏主循环,遍历他,当某个精灵死了之后,先从List中把他erase掉,然后将精灵本身removeFromParentAndCleanUp。

运行毫无问题,但程序一退出就会出现上述错误。

打断点,原因如下:

1,当对象被销毁时,他的成员变量,也就是上述的三个List也会进入各自的销毁流程;

2,但是由于这三个List中装的精灵是有重叠的,我从AllSpriteList的遍历中清除了某个友方精灵,那么FriendList在销毁的时候还会去试图清除这个精灵!!(因为List中保存的仅仅是精灵的指针,并非精灵对象本身)

 

结论:尽量避免多个List中的元素重叠

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。

发布者:全栈程序员-用户IM,转载请注明出处:https://javaforall.cn/172115.html原文链接:https://javaforall.cn

【正版授权,激活自己账号】: Jetbrains全家桶Ide使用,1年售后保障,每天仅需1毛

【官方授权 正版激活】: 官方授权 正版激活 支持Jetbrains家族下所有IDE 使用个人JB账号...

(0)


相关推荐

发表回复

您的电子邮箱地址不会被公开。

关注全栈程序员社区公众号