记一个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里,还有调用栈上的引用。
翻译

搜索

复制

相关推荐
叶帆14 天前
【YFIOs】用C#开发硬件之设备上云
开发语言·unity·c#
久数君14 天前
AI三维建模工具“造形家”:地理场景三维化的高效解决方案
unity·glb·ai算法·ai三维建模工具·地图框选·造形家·城市建筑模型
会思考的猴子14 天前
Unity VFX 属性 Postion 和 TargetPostion
unity
hai31524754314 天前
九章编程法 · 猜数字游戏 (GW-BASIC 重构版) *
人工智能·microsoft·游戏引擎·游戏程序
心前阳光14 天前
Unity资源导入之自动化资源导入
unity·自动化·游戏引擎
心前阳光14 天前
Unity之2021.3.45f2c1发布安卓程序遇到的问题
android·unity·游戏引擎
纪纯15 天前
PicoVR Unity Integration SDK 3.4 常用交互API
unity·游戏引擎·vr·pico
龙智DevSecOps解决方案15 天前
3A 游戏优化技术栈:如何打通引擎级分析工具与 DevOps 持续集成管线?
unity·性能优化·游戏开发·技术美术·perforce·unrealengine
葛兰岱尔15 天前
从 SolidWorks 到 Three.js,从 Inventor 到 Unity——制造业CAD模型“几何-语义一体化“转换,不再是天方夜谭!
开发语言·javascript·unity
鼎艺创新科技15 天前
三维电子沙盘中OSGB倾斜摄影数据的加载与渲染
游戏引擎·cocos2d