您当前的位置: 首页 >  unity

染指流年灬

暂无认证

  • 2浏览

    0关注

    194博文

    0收益

  • 0浏览

    0点赞

    0打赏

    0留言

私信
关注
热门博文

[Unity3D 实践] 小测试 GetComponent()函数的效率

染指流年灬 发布时间:2022-05-10 12:45:26 ,浏览量:2

GetComponent()的3种重载版本

T GetComponent()
Component GetComponent(Type type)
Component GetComponent(string type)

在Unity3D脚本中,我们通过调用Component类的GetComponent函数来获取GameObject上的组件,那么:

各版本GetComponent方法的执行效率究竟如何?

如果在脚本中建立局部变量保存常用组件对象的引用(避免重复调用GetComponent()方法),究竟能提升多少效率?

结论
运行效率排名: 局部变量 >> GetComponent() > GetComponent(Type type) >> GetComponent(string type)

自定义组件:

调用局部变量大约比调用GetComponent()方法快1个数量级以上
GetComponent(string type)相比另外两个重载版本慢接近2个数量级
GetComponent(Type type) 和 GetComponent(string type)的返回值是Component类型的对象,使用前还需要进行一次类型转换
transform组件:

调用局部变量比调用Component静态变量transform稍微快一些,时间消耗比例大致为 5:8

测试过程

在Unity3D场景中新建一个GameObject,挂一个下面的脚本,运行游戏,点击右键进行测试。

using UnityEngine;
using System;
 
public class TestComponent : MonoBehaviour {
 
    public Vector3 position = Vector3.zero;
 
    private void Update()
    {
        if (Input.GetMouseButtonDown(1))
        {
            int times = 1000 * 100;
            Vector3 pos;
 
            Transform localTransform = transform;
            Debug.Log("开始测试:");
 
            //测试Transform组件
            TestExecuteSpeed("GetComponent(string Transform)", () => { pos = ((Transform)GetComponent("Transform")).position; }, times);
            TestExecuteSpeed("GetComponent(Type Transform)", () => { pos = ((Transform)GetComponent(typeof(Transform))).position; }, times);
            TestExecuteSpeed("GetComponent()", () => { pos = GetComponent().position; }, times);
            TestExecuteSpeed("Component.transform", () => { pos = transform.position; }, times);
            TestExecuteSpeed("local transform", () => { pos = localTransform.position; }, times);
 
 
            //测试自定义组件
            TestComponent testComponent = this;
            TestExecuteSpeed("GetComponent(string TestComponent)", () => { pos = ((TestComponent)GetComponent("TestComponent")).position; }, times);
            TestExecuteSpeed("GetComponent(Type TestComponent)", () => { pos = ((TestComponent)GetComponent(typeof(TestComponent))).position; }, times);
            TestExecuteSpeed("GetComponent()", () => { pos = GetComponent().position; }, times);
            TestExecuteSpeed("local testComponent", () => { pos = testComponent.position; }, times);
        }
    }
 
    //测速泛型方法
    static void TestExecuteSpeed(string taskName, Action Task, int times)
    {
        int repeatTimes = 3;
        float totalTime = 0f;
        float stopWatch;
        for (int i = 0; i             
关注
打赏
1665909078
查看更多评论
0.0367s