for和foreach哪个执行效率快,相信很多人都会说当然是foreach快啊,在我实验之前我也是这么认为的,直到今天。费话不多说,下面是测试的结果,区分Debug和Release,数据采用int[],List<int>,Person[],List<Pserson>,DataTable:

+++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++

Debug下

初始化5千万整型数据...
初始化整型数据完成。耗时:650

使用For遍历10次整型数组,求平均时间...
For循环整型数组平均时间:202.9

使用Foreach遍历10次整型数组,求平均时间...
Foreach循环整型数组平均时间:236.8

使用For遍历10次整型List,求平均时间...
For循环整型List平均时间:360.9

使用Foreach遍历10次整型List,求平均时间...
Foreach循环整型List平均时间:269

---------------------------------------

初始化5千万Object数据...
初始化Object数据完成。耗时:193656

使用For遍历10次Object数组,求平均时间...
For循环Object数组平均时间:930

使用Foreach遍历10次Object数组,求平均时间...
Foreach循环Object数组平均时间:1130.9

使用For遍历10次ObjectList,求平均时间...
For循环ObjectList平均时间:923.7

使用Foreach遍历10次ObjectList,求平均时间...
Foreach循环ObjectList平均时间:1282.8

---------------------------------------

初始化2千万DataTable数据...
初始化时间:115291

使用For遍历10次DataTable,求平均时间...
For循环DataTable平均时间:12014.4

使用Foreach遍历10次DataTable,求平均时间...
Foreach循环DataTable平均时间:3804.4

Release====================================================================================================================

初始化5千万整型数据...
初始化整型数据完成。耗时:513

使用For遍历10次整型数组,求平均时间...
For循环整型数组平均时间:41.1

使用Foreach遍历10次整型数组,求平均时间...
Foreach循环整型数组平均时间:46.4

使用For遍历10次整型List,求平均时间...
For循环整型List平均时间:168.9

使用Foreach遍历10次整型List,求平均时间...
Foreach循环整型List平均时间:165.3

-------------------------------------------------------

初始化5千万Object数据...
初始化Object数据完成。耗时:157782

使用For遍历10次Object数组,求平均时间...
For循环Object数组平均时间:38

使用Foreach遍历10次Object数组,求平均时间...
Foreach循环Object数组平均时间:490.2

使用For遍历10次ObjectList,求平均时间...
For循环ObjectList平均时间:365.5

使用Foreach遍历10次ObjectList,求平均时间...
Foreach循环ObjectList平均时间:726.6

----------------------------------------------------

初始化2千万DataTable数据...
初始化时间:114483

使用For遍历10次DataTable,求平均时间...
For循环DataTable平均时间:12059

使用Foreach遍历10次DataTable,求平均时间...
Foreach循环DataTable平均时间:3891.8

++++++++++++++++++++++++++++++++++++++++++++++

由此可以看出不同的数据结构,for和foreach执行效率是不一样的,不能说哪个一定快。有些数据结构差别不大,有些差别就比较大。

以上测试条件为:

电脑型号 X64 兼容 台式电脑
操作系统 Windows 7 旗舰版 64位 ( DirectX 11 )
处理器 AMD FX -8320 Eight-Core 八核
主板 华硕 M5A78L-M LX3 PLUS ( AMD 780G/780V/790GX/890GX )
内存 8 GB ( 金士顿 DDR3 1600MHz )

C# for 和 foreach的执行效率的更多相关文章

  1. php代码优化系列 -- array_walk 和 foreach, for 的效率的比较

    实验是我学习计算机科学的一个重要方法,计算机科学不是简单的智力游戏,它本质上来说不是一门科学,而是一个改造世界的工具.数学方法和实验方法是计算机研究的基本方法,也是我们学习的基本方法,数学锻炼我们的思 ...

  2. Snapman系统中TCC执行效率和C#执行效率对比

    Snapman集合了TCC编译器可以直接编译执行C语言脚本,其脚本执行效率和C#编译程序进行效率对比,包括下面4方面: 1.函数执行效率 2.数字转换成字符串 3.字符串的叠加 4.MD5算法 这是C ...

  3. 五十个小技巧提高PHP执行效率

    在项目开发过程中,经常遇到了一些PHP处理程序性能底下的情况,程序运行在centos+nginx环境,虽然这个有很多的原因如:服务器本身配置,运行环境nginx服务,php-fpm配置等等,更多有一点 ...

  4. php代码优化 -- array_walk 和 foreach, for 的效率的比较

    <?php /** * array_walk 和 foreach, for 的效率的比较. * 我们要测试的是foreach, for, 和 array_walk的效率的问题. */ //产生一 ...

  5. PHP对接口执行效率慢的优化

    PHP对接口执行效率慢的优化 PHP对接口执行效率慢的优化 造成执行效率低的原因可以由很多方面找原因 从代码层面,代码质量低,执行效率也会有很大影响的. 从硬件方面,服务器配置低,服务器配置是基础,这 ...

  6. 参数探测(Parameter Sniffing)影响存储过程执行效率解决方案

    如果SQL query中有参数,SQL Server 会创建一个参数嗅探进程以提高执行性能.该计划通常是最好的并被保存以重复利用.只是偶尔,不会选择最优的执行计划而影响执行效率. SQL Server ...

  7. SQL Server SQL性能优化之--通过拆分SQL提高执行效率,以及性能高低背后的原因

    复杂SQL拆分优化 拆分SQL是性能优化一种非常有效的方法之一, 具体就是将复杂的SQL按照一定的逻辑逐步分解成简单的SQL,借助临时表,最后执行一个等价的逻辑,已达到高效执行的目的 一直想写一遍通过 ...

  8. SQL Server 并行操作优化,避免并行操作被抑制而影响SQL的执行效率

    为什么我也要说SQL Server的并行: 这几天园子里写关于SQL Server并行的文章很多,不管怎么样,都让人对并行操作有了更深刻的认识. 我想说的是:尽管并行操作可能(并不是一定)存在这样或者 ...

  9. SQL执行效率和性能测试方法总结

    对于做管理系统和分析系统的程序员,复杂SQL语句是不可避免的,面对海量数据,有时候经过优化的某一条语句,可以提高执行效率和整体运行性能.如何选择SQL语句,本文提供了两种方法,分别对多条SQL进行量化 ...

随机推荐

  1. 通过域 组策略禁用U盘(只允许部份许可U盘可在客户端读取)

    U盘禁用设置步骤: 1.客户端 注册表修改,USBStor  的start改为4 HKEY_LOCAL_MACHINE\SYSTEM\CurrentControlSet\Services\UsbSto ...

  2. 解决电信或网通的DNS劫持

    大家有没有碰到访问一些不存在域名或者网站时,浏览器本应显示一个网址不存在之类的信息,但是因为现在很多ISP做了DNS劫持将不存在的域名或网址重定向到ISP的广告页面,烦人的狠.其实tomato可以解决 ...

  3. BZOJ一句话

    一句话题解集合. 1061: [Noi2008]志愿者招募 单纯形,运用对偶原理转化过来,变成标准形然后单纯性裸上即可. #include<cmath> #include<cstdi ...

  4. Tensorflow 学习笔记 -----gradient

    Tensorflow 的求梯度函数: [db, dW, dx] = tf.gradient(C, [b, w, x]) 在调试时用处较大. 实例: import tensorflow as tf im ...

  5. js实现table排序(jQuery下的jquery.sortElements)

    项目中要实现table排序的功能. 网上有非常多解决方式,非常多都基于jQuery. jquery.tablesorter.大小17KB.只是他的首页在ie10下兼容性有点问题. DataTables ...

  6. C语言利用 void 类型指针实现面向对象类概念与抽象

    不使用C++时,很多C语言新手可能认为C语言缺乏了面向对象和抽象性,事实上,C语言通过某种组合方式,可以间接性的实现面对对象和抽象. 不过多态和继承这种实现,就有点小麻烦,但是依然可以实现. 核心: ...

  7. Scott Hanselman的问题-2

    .Net程序员面试 每个人都应知道篇 (回答Scott Hanselman的问题)   昨天回答了Scott Hanselman在他清单上关于C#那部分的题目,.Net 程序员面试 C# 语言篇 (回 ...

  8. 游标 scroll

    scroll表示可随意移动游标指针(否则只能向前)

  9. 最大子段和 模板题 51Nod 1049

    N个整数组成的序列a[1],a[2],a[3],…,a[n],求该序列如a[i]+a[i+1]+…+a[j]的连续子段和的最大值.当所给的整数均为负数时和为0. 例如:-2,11,-4,13,-5,- ...

  10. P1145 约瑟夫

    P1145 约瑟夫 题目描述 n个人站成一圈,从某个人开始数数,每次数到m的人就被杀掉,然后下一个人重新开始数,直到最后只剩一个人.现在有一圈人,k个好人站在一起,k个坏人站在一起.从第一个好人开始数 ...