for语句嵌套循坏性能的剖析
日常工作中,处理数据难免会遇到遍历,for循环可能是我们用的比较多的了。本节就来探讨下for语句嵌套循环的性能,猜想下面两个语句的性能。
语句1
for ( i= ; i < ; i++)
{
for (j =; j < ; j++)
{
expression;
}
}
语句2
for ( i= ; i < ; i++)
{
for (j =; j < ; j++)
{
expression;
}
}
乍一看,感觉两个嵌套循环执行的次数都是一样的,那么他们的时间复杂度是一样的吗?让我们来分析下,语句1外层循环执行了1000000次,内层循环执行了1000000*100次,而语句2外层循环执行了100次,内层循环也执行了1000000*100次。那么,既然内层执行的次数都一样,外层是不是执行的越少越好呢?让我们写代码认证下。
验证代码
static void Main(string[] args)
{
Stopwatch sw = new Stopwatch();
sw.Start();
for (int i = ; i < ; i++)
{
for (int j = ; j < ; j++)
{
// expression;
}
}
sw.Stop();
Console.WriteLine(sw.ElapsedMilliseconds); sw.Reset(); sw.Start();
for (int i = ; i < ; i++)
{
for (int j = ; j < ; j++)
{
// expression;
}
}
sw.Stop();
Console.WriteLine(sw.ElapsedMilliseconds);
}
验证截图

得出结论,对于for语句的嵌套循环,总循环次数相等,外层循环越小越好。个人拙见,工作中具体情况具体对待...
补充总结(2月3日)
上文的描述给大家展现的都是现象,并没有告诉大家事物的本质。(@Sunday*)Sunday*告诉我说“是因为减少了对int j=0的赋值操作,这些会有一定的性能上的消耗,但这种优化不是本质上的性能提升!”,于是引发了我更深层次的思考。其实,控制外层循环次数越小,我们可以发现i自增的次数少了,i<100的判断次数少了,以及内层循环中的int j=0赋值的次数也少了,自然而然性能就得到了提升。
Sunday*说的很对:使用for应尽量避免里面创建对象,减少循环次数,这样才能达到优化;而我得出的结论:对于for语句的嵌套循环,总循环次数相等,外层循环越小越好。两者都是正确的。代码是死的,人是活的,人得灵活驾驭代码,具体情况具体对待。
最后,我不否认这种优化对性能提升不了多少,但是,假如我遇到了本文所提的情况,我必须得本能得写出最优代码,这也是我研究的目的所在。
for语句嵌套循坏性能的剖析的更多相关文章
- 1、python简介-变量-注释-数据类型-用户交互-if语句-while循坏
		
一. 计算机是什么 基本组成: 主板+cpu+内存 cpu: 主频, 核数(16) 内存:大小(8G, 16G, 32G) 型号: DDR3, DDR4, DDR5, 主频(海盗船,玩家国度) 显卡: ...
 - 流程控制之while循坏
		
流程控制之while循坏 一.语法 循环就是一个重复的过程,我们人需要重复干一个活,人岂不是要累死啊,而且还是那么-..的枯燥乏味,向我这样要的小年轻,不骚里骚气的行吗?那岂不是白白流浪了这么多年头, ...
 - python while循坏和for循坏
		
while循坏 while 条件: 条件成立,执行循坏体(注意,while循坏必须有结束条件,不然会进入死循坏) 简单做个演示: # -*- coding:utf-8 -*- # Author:覃振鸿 ...
 - MySQL查询语句执行过程及性能优化(JOIN/ORDER BY)-图
		
http://blog.csdn.net/iefreer/article/details/12622097 MySQL查询语句执行过程及性能优化-查询过程及优化方法(JOIN/ORDER BY) 标签 ...
 - java(5)循坏结构
		
一. while循环 1.循环的优点? 减少重复代码的编写:程序会更加的简洁 2.语法 while(表达式){ // 1.表达式是[循环条件],结果必须是boolean类型 //2.{}中的代码,即[ ...
 - JAVA之旅(二)——if,switch,for,while,do while,语句嵌套,流程控制break , continue ,函数,重载的示例总结
		
JAVA之旅(二)--if,switch,for,while,do while,语句嵌套,流程控制break , continue ,函数,重载的示例总结 JAVA的思想真的很重要,所以要专心的学-- ...
 - MySQL 笔记整理(18) --为什么这些SQL语句逻辑相同,性能却差异巨大?
		
笔记记录自林晓斌(丁奇)老师的<MySQL实战45讲> (本篇内图片均来自丁奇老师的讲解,如有侵权,请联系我删除) 18) --为什么这些SQL语句逻辑相同,性能却差异巨大? 本篇我们以三 ...
 - MySQL查询语句执行过程及性能优化-查询过程及优化方法(JOIN/ORDER BY)
		
在上一篇文章MySQL查询语句执行过程及性能优化-基本概念和EXPLAIN语句简介中介绍了EXPLAIN语句,并举了一个慢查询例子:
 - Python3 循环_break和continue语句及循环中的else子句
		
break和continue语句及循环中的else子句break语句可以跳出for和while的循环体.如果你从for或while循环中终止,任何对应的循环else块将不执行. continue语句被 ...
 
随机推荐
- android 悬浮覆盖状态栏的相关建议
			
WindowManager.LayoutParams.TYPE_SYSTEM_ERROR 显示在所有的应用之上包括显示在状态栏上,相对于TYPE_SYSTEM_OVERLAY不能获取焦点更为理想. 另 ...
 - HTML空格标签
			
双学位论文+本学位开题报告+实训项目+实训考试+学员考试,真是脑子都要爆炸... 话不多说,留个小知识点,HTML的空格替代符号表示法: 1. 半个空白,1个字符宽度: 或者 2.1个空白,2个 ...
 - Evacuation Plan-POJ2175最小费用消圈算法
			
Time Limit: 1000MS Memory Limit: 65536K Special Judge Description The City has a number of municipal ...
 - redis持久化配置
			
redis有rdb和aof两种持久化方式: rdb 默认方式,配置文件中相关的有: save 900 1 #900秒一次,若有1个或以上key修改则save一次,以下相同 save 300 10 sa ...
 - 使用MegaCli工具查看Raid磁盘阵列状态
			
转载自:http://home.51.com/chenjianghui1987/diary/item/10051836.html 文章本身我不做过多修改了,在这里我就把自己在安装时候碰到的难点跟大家提 ...
 - 描述性统计分析-用脚本将统计量函数批量化&分步骤逐一写出
			
计算各种描述性统计量函数脚本(myDescriptStat.R)如下: myDescriptStat <- function(x){ n <- length(x) #样本数据个数 m &l ...
 - Eclipse通过DDMS打开真机/data/data/目录
			
一般真机调试时DDMS里面的File Explorer是不能打开/data 目录的,不过也很容易解决. 1.首先手机要root.这个很简单,网上一大堆资料和软件. 2.仅仅root之后还不行,下载一个 ...
 - dm9000网口收发控制以及mac地址过滤设置
			
目的 :完成网口收发调试 过程 : 1.网口初始化,根据芯片数据手册配置 2.网口发数,先向DM9000中的TX FIFO存入数据,然后出发发送寄存器完成发送: 3.网口接收 . ...
 - 《与小卡特一起学Python》 Code6 注释
			
"""这是一个包括多行的注释, 使用了三重引号字符串. 这不完全是注释,不过也可以相当于注释. """ #***************** ...
 - validate插件深入学习-04自定义验证方法
			
自定义验证方法 jQuery.validator.addMethod(name,method,[,message]) name: 方法名 method: function(value,element, ...