C# 中 for和foreach 性能比较,提高编程性能
From: http://www.cnblogs.com/yzxchoice/archive/2007/12/15/995949.html
在很多情况下for和foreach具有同样的功能,选择for还是foreach很多人可能都是看自己的喜好,本测试试图通过 来真是测试数据来比较他们的执行效率。希望能给大家对他们的时候带来一些帮助。
测试环境:
硬件环境: PIII800 + CPU456
软件环境: VisualStudio.Net + C#
测试用例:
利用结果集来存放记录,初始化对结果集添加记录
分别对记录数为10000,100000,1000000条记录的时候进行采样分析
关键测试对比代码如下,功能完全一样:
//foreach开始时间
datetime3 = System.DateTime.Now.TimeOfDay.ToString();
foreach(DataRow row in relationData.Tables[RelationData.RELATIONINFO_TABLE].Rows)
buffer = row[RelationData.PK_TABLE_NAME].ToString();
datetime4 = System.DateTime.Now.TimeOfDay.ToString();
//for开始时间
datetime5 = System.DateTime.Now.TimeOfDay.ToString();
for(int j=0;j<1000000;j++)
buffer = relationData.Tables[RelationData.RELATIONINFO_TABLE].Rows[j][RelationData.PK_TABLE_NAME].ToString();
datetime6 = System.DateTime.Now.TimeOfDay.ToString();
测试结果:
10000条记录时:
foreach读取时间:16:29:34.2577584
foreach结束时间:16:29:34.2677728
for读取开始时间:16:29:34.2677728
for读取结束时间:16:29:34.2878016
100000条记录时:
foreach读取时间:16:31:10.1055808
foreach结束时间:16:31:10.1957104
for读取开始时间:16:31:10.1957104
for读取结束时间:16:31:10.4460704
1000000条记录时:
foreach读取时间:16:33:12.6217504
foreach结束时间:16:33:13.6332048
for读取开始时间:16:33:13.6332048
for读取结束时间:16:33:18.7906208
结果分析:
1)对于10000条记录可以看出
foreach用了 0.0100144
for循环用了0.0300432
foreach所花的时间正好是for循环的 1/3
2)对于100000条记录可以看出
foreach用了0.0901296
for循环用了0.2503600
foreach所花的时间是for循环的 36%
3)对于1000000条记录结果可以看出
foreach用了1.0114544
for循环用了4.1574160
foreach所花的时间是for循环的 25%
通过对这些测试结果的分析,可以看出相对于原来的for语句foreach具有
更好的执行效率,foreach的平均花费时间只有for30%。通过测试结果在for和foreach都可以使用的情况下,我 们推荐使用效率更高的foreach.在测试同时
我们附加的发现,用for写入数据时间大约是读取数据时间的10倍左右
C# 中 for和foreach 性能比较,提高编程性能相关推荐
- 电脑性能,如何提高电脑性能 方法介绍【图文教程】
在这个信息传播飞速的当下,网络是人们必不可少的传播工具,网络传播信息的途径就是通过电脑,电脑如今已经是每家每户的宠儿了,几乎每个人都有自己的电脑.然而电脑与电脑之间也有差异,它们最大的不同就是性能方面 ...
- mysql insert 性能_MySQL 提高Insert性能
插入一个记录需要的时间由下列因素组成,其中的数字表示大约比例: 连接:(3) 发送查询给服务器:(2) 分析查询:(2) 插入记录:(1x记录大小) 插入索引:(1x索引) 关闭:(1) 这不考虑打开 ...
- Win11游戏性能设置 提高游戏性能方法
很多用户担心升级Win11系统之后会影响游戏体验感,但是要是做好性能优化,将赋予游戏更大的空间去提升效果和玩法.那Win11怎么提高游戏性能呢?下面我们就来一起看看. Win11 ...
- ps软件怎么测试性能,怎么样提高Photoshop性能,让PS软件快速启动
该楼层疑似违规已被系统折叠 隐藏此楼查看此楼 photoshop做为强大的图像处理软件,当我们在运行的时候,往往要让大家耐心等待一段时间.其实,通过一些设置,我们完全可以提高Photoshop运行的时 ...
- 安卓性能优化——提高编码性能的技巧
引用了大量API文档的内容,没有对超链接进行删改,有需要的朋友可以直接点超链接访问API文档. 上一篇关于主要内存的性能优化,这一篇主要关于编码. Performance tips This docu ...
- 高性能MySQL学习——提高查询性能
高性能MySQL学习--提高查询性能 提高查询性能 MySQL 查询优化器 MySQL 执行计划分析"三步曲" MySQL 执行计划查询分析 如何优化 SQL MySQL 自身优化 ...
- Linux中使用异步 I/O 大大提高应用程序的性能
Linux中使用异步 I/O 大大提高应用程序的性能 原文: http://www.ibm.com/developerworks/cn/linux/l-async/ AIO 简介 Linux 异步 I ...
- 在程序开发中怎样写SQL语句可以提高数据库的性能
1.首先要搞明白什么叫执行计划? 执行计划是数据库根据SQL语句和相关表的统计信息作出的一个查询方案,这个方案是由查询优化器自动分析产生的,比如一条SQL语句如果用来从一个10万条记录的表中查1条记录 ...
- 【DB笔试面试594】在Oracle中,关键字NOLOGGING、APPEND和PARALLEL提高DML性能方面有什么差别?...
♣题目部分 在Oracle中,关键字NOLOGGING.APPEND和PARALLEL提高DML性能方面有什么差别? ♣答案部分 众所周知,表模式(LOGGING/NOLOGGING).插入模式(AP ...
最新文章
- Linux环境下Redis集群实践
- foreach 循环详解
- HDU 1033 水题
- android 阻塞式函数,Android之PC浏览器上传表单格式大文件到手机客户端read函数阻塞问题...
- 万源之源之drupal7
- symbian使用活动对象时返回-2147483647错误值的解决办法
- f2fs解析(四)f2fs的extent特性
- 在MFC对话框中显示html网页
- 缓存击穿 穿透 雪崩_缓存雪崩、缓存穿透、缓存击穿的问题
- linux内核怎么变化,Linux内核中CPU状态变化机制简介
- RestClient
- 数学 二维向量(加法、减法、模、点乘、叉乘)
- 推荐]该内存不能为“read”或“written”的解决方案!
- Android ViewPager 自定义翻页动画
- Win7系统盘瘦身。
- KDD 2021 | 基于多智能体协同竞价博弈的电商搜索广告多目标竞价优化
- IDEA报错:不支持发行版本
- Mysql笔试+面试题积累(实时更新)
- Arya and Bran Game of the Rows Multiple Clocks
- Android Ringtone 自定义铃声介绍
热门文章
- Pytorch构建模型的3种方法
- 1971. Find if Path Exists in Graph
- 剑指 Offer 53 - I. 在排序数组中查找数字 I(二分法)
- Docker 入门(4)镜像与容器
- Docker 入门(2)技术实现和核心组成
- 数据结构与算法深入学习_我最喜欢的免费课程,用于深入学习数据结构和算法...
- github大学课程_GitHub基础教程:如何使用GitHub课程
- delphi5开发人员指南_非设计人员的网页设计开发人员指南
- 知识力量_网络分析的力量
- java 获取手机归属地,引起net.UnknownHostException错误