Unity C#for和foreach效率比较

 

 下面是代码自己测试一下即可

using System.Collections;
using System.Collections.Generic;
using UnityEngine;

public class TimeDuiBi : MonoBehavIoUr
{
    List<int> list = new List<int>();

    private void Start()
    {
        for (int i = 0; i < 3000000; i++)
        {
            list.Add(i);
        }    
    }
    private void Update()
    {
        if (Input.GetKeyDown(KeyCode.Space))
        {
            System.Diagnostics.Stopwatch stopwatch = new System.Diagnostics.Stopwatch();
            stopwatch.Start();
            int temp1 = 0;
            int cout = list.Count;
            for (int i = 0; i < cout; i++)
            {
                temp1 += list[i];
            }
            stopwatch.Stop();
            Debug.Log("for time=: " + stopwatch.Elapsed.TotalMilliseconds + "temp1:" + temp1);


            System.Diagnostics.Stopwatch stopwatch2 = new System.Diagnostics.Stopwatch();
            stopwatch2.Start();
            int temp3 = 0;
            for (int i = 0; i < list.Count; i++)
            {
                temp3 += list[i];
            }
            stopwatch2.Stop();
            Debug.Log("for list.Count  time=: " + stopwatch2.Elapsed.TotalMilliseconds + "temp3:" + temp3);


            System.Diagnostics.Stopwatch stopwatch1 = new System.Diagnostics.Stopwatch();
            stopwatch1.Start();
            int temp2 = 0;
            foreach (var item in list)
            {
                temp2 += item;
            }
            stopwatch1.Stop();
            Debug.Log("foreach time=: " + stopwatch1.Elapsed.TotalMilliseconds + "temp2:" + temp2);
        }
    }
}

 

以上就是测试的结果,不喜勿喷

 

搜索

复制

<iframe></iframe>

相关文章

实现Unity AssetBundle资源加载管理器 AssetBundle是实现资源...
Unity3D 使用LineRenderer绘制尾迹与虚线 1.添加LineRendere...
Unity 添加新建Lua脚本选项 最近学习Unity的XLua热更新框架的...
挂载脚本时文件名和类名的关联方式 写过Unity脚本的人应该都...
Unity单例基类的实现方式 游戏开发的过程中我们经常会将各种...
这篇文章主要介绍了Unity游戏开发中外观模式是什么意思,具有...