[Unity3D]关于为什么保存Transform等引用效率会更高
2014-11-13 15:19
1026 查看
原文链接
正常来说,大部分同学一般get transform都直接gameobject.transform使用。但往往,你会发现有些人会将transform引用保存起来,例如:
private Transform myTransform;
void Awake() {
myTransform = transform;
}
然后使用myTransform替代this.transform。如果你不知道u3d内部实现获取方式你肯定会以为这人脑抽水了,有直接的不用,还自己保存起来。
this.transform并不是变量,而是一个get/set属性(property)。
using System;
using System.Runtime.CompilerServices;
using UnityEngineInternal;
namespace UnityEngine
{
public class Component : Object
{
public extern Transform transform
{
[WrapperlessIcall]
[MethodImpl(MethodImplOptions.InternalCall)]
get;
}
}
}
调用this.transform实际上是一个调用intenal method的过程(这是用C/C++写的,不是MONO的)。值得注意的是这个调用方法略慢,因为你需要调用外部的CIL(aka interop),花费了额外的性能。
估计大概的效率(没测试,以后有时间再弄,大家可以参考下文章最后的链接):
GetComponent是this.transform的10倍消耗时间。
this.transform是保存了引用myTransform的1.5倍的消耗时间。(因为新版优化了不少)
实际上:
如果你是偶尔调用一下transform的话,那就不要保留它的引用了,直接this.transform。
如果是Update中,每一帧都要改变的话,还是保留一下this.transform的引用吧。毕竟倘若一大堆东西的话,能快不少呢。
详细参考:
http://forum.unity3d.com/threads/130359-How-does-caching-an-objects-transform-make-the-game-run-faster http://forum.unity3d.com/threads/96908-Unity-should-internally-cache-transform-for-a-valid-speed-boost http://forum.unity3d.com/threads/130365-CachedMB
正常来说,大部分同学一般get transform都直接gameobject.transform使用。但往往,你会发现有些人会将transform引用保存起来,例如:
private Transform myTransform;
void Awake() {
myTransform = transform;
}
然后使用myTransform替代this.transform。如果你不知道u3d内部实现获取方式你肯定会以为这人脑抽水了,有直接的不用,还自己保存起来。
this.transform并不是变量,而是一个get/set属性(property)。
using System;
using System.Runtime.CompilerServices;
using UnityEngineInternal;
namespace UnityEngine
{
public class Component : Object
{
public extern Transform transform
{
[WrapperlessIcall]
[MethodImpl(MethodImplOptions.InternalCall)]
get;
}
}
}
调用this.transform实际上是一个调用intenal method的过程(这是用C/C++写的,不是MONO的)。值得注意的是这个调用方法略慢,因为你需要调用外部的CIL(aka interop),花费了额外的性能。
估计大概的效率(没测试,以后有时间再弄,大家可以参考下文章最后的链接):
GetComponent是this.transform的10倍消耗时间。
this.transform是保存了引用myTransform的1.5倍的消耗时间。(因为新版优化了不少)
实际上:
如果你是偶尔调用一下transform的话,那就不要保留它的引用了,直接this.transform。
如果是Update中,每一帧都要改变的话,还是保留一下this.transform的引用吧。毕竟倘若一大堆东西的话,能快不少呢。
详细参考:
http://forum.unity3d.com/threads/130359-How-does-caching-an-objects-transform-make-the-game-run-faster http://forum.unity3d.com/threads/96908-Unity-should-internally-cache-transform-for-a-valid-speed-boost http://forum.unity3d.com/threads/130365-CachedMB
相关文章推荐
- [Unity3D]关于为什么保存Transform等引用效率会更高
- 关于为什么保存Transform等引用效率会更高
- 关于为什么保存Transform等引用效率会更高
- 关于为什么保存Transform等引用效率会更高
- Unity3D 为什么保存Transform等引用效率会更高
- 关于Unity3D中的空引用 Null Reference Exception
- 关于EDM模型中多个实体之间循环引用导致保存数据失败的解决方案一例
- Unity3D 为什么Transform.Translate 中的x/y/z值经常会通过speed * Time.deltaTime获取?应该这样的
- unity3d 关于c#命名空间引用问题
- 【概念】为什么有时全表扫描比通过索引扫描效率更高
- [Unity3d]关于红米2和小米2等安卓手机为什么不支持 ETC2压缩模式
- 为什么有时全表扫描比通过索引扫描效率更高
- Java 关于提高效率的小原则---多层对象引用会浪费时间!
- 一道scjp题,关于java 变量引用的,知道为什么输出10,20吗?
- 关于 “引用类型保存在堆上,值类型保存在栈上”是不准确的
- Mysql为什么企业一般使用InnoDB引擎而不是使用效率更高的MyISAM引擎?
- 前置++为什么比后置++效率更高?
- Unity3D关于内存优化,内存泄露、多线程、引用C++的dll的问题研究
- 为什么有时全表扫描比通过索引扫描效率更高 (转)
- 关于更高效率做事的一些思考