记一个Unity的异常问题

今天同事给我反馈了一个Unity使用ThreadStatic的问题,问题如下:

cs 复制代码
    [ThreadStatic]
    private static Dictionary<int, Mesh> dic;
    
    IEnumerator Start()
    {
        dic = new Dictionary<int, Mesh>();
        dic.Add(0, new Mesh());
        yield return Resources.UnloadUnusedAssets();
        Debug.Log(dic[0] == null);
        yield return null;
    }

这段代码,会打印true。也就是Resource.UnloadUnusedAssets会把持有引用的Mesh对象给回收掉。

如果去掉字典的ThreadStatic属性,就没有问题。

ThreadStatic会将静态字段标记为线程安全的,也就是每个线程将有一份自己的该字段存储。

我们推测,Resources.UnLoadUnsedAssets方法是在别的线程执行的,在那个线程里,垃圾收集器并没有检测到Mesh的引用,于是就把Mesh的Native内存给销毁了。这些目前还都支持推测,因为没有源码,也看不到具体的逻辑。

查了一些资料,最早Unity官方是有发文说,不要使用ThreadStatic,会引发Crash,不过我们用了也没有引发Crash。

所以目前成了一个有结论但不确定原因的技术问题了。

总而言之:

1、用可以用,但是只针对纯C#的数据结构进行使用。不要对继承自Unity.Ojbect的对象相关使用ThreadStatic标记

2、如果想要使用,可以在Resource.UnloadUnsedAssets之前写上一句

var refDic = dic;

即便只是局部变量对字典产生了引用,就又没有这个问题了。因为垃圾回收除了静态变量,Hirerachy里,还有调用栈上的引用。
翻译

搜索

复制

相关推荐
tedcloud12341 分钟前
ppt-master部署教程:快速搭建智能演示文稿系统
服务器·人工智能·系统架构·游戏引擎·powerpoint
垂葛酒肝汤21 小时前
Unity的UI扫光效果Shader
ui·unity·游戏引擎
mxwin1 天前
Unity Shader Alpha测试 · 模板测试 · 深度测试
unity·游戏引擎
2601_956002811 天前
冬日狂想曲(赠去马赛克补丁)2026.5.13最新版免费下载 转存后自动更新 (看到请立即转存 资源随时失效)pc手机版通用
智能手机·游戏引擎·电脑·游戏程序·动画·游戏美术
Sator11 天前
unity解决粒子与物体接触时的硬边缘问题
unity·游戏引擎
RPGMZ1 天前
RPGMZ NPC头顶自动显示一段消息
前端·游戏引擎·rpgmz·rpgmakermz
程序员JerrySUN1 天前
Jetson边缘嵌入式实战课程第三讲:L4T 与 Jetson 系统架构
linux·服务器·人工智能·安全·unity·系统架构·游戏引擎
萌萌的提莫队长1 天前
Unity HDRP 渲染管线 Camera 输出到RenderTexture没有Alpha通道
unity·游戏引擎
winlife_1 天前
Unity Editor 工具不该用反射写组件字段:SerializedObject 在 4 个场景里非用不可
unity·自动化·游戏引擎
星河耀银海1 天前
Unity C#入门:变量的定义与访问权限(public/private)
unity·c#·lucene