談C#中循環(huán)結(jié)構(gòu)的效率問(wèn)題
順序、選擇、循環(huán)是一切程序的三大結(jié)構(gòu)。今天我們就來(lái)說(shuō)一說(shuō)C#中循環(huán)結(jié)構(gòu)的一個(gè)小問(wèn)題。
c#的循環(huán)結(jié)構(gòu)有四種:
- for
- while…do…
- do…while…
- foreach
在這四種結(jié)構(gòu)中,都有循環(huán)結(jié)束的判斷。大于某個(gè)數(shù)字,小于某個(gè)數(shù)字,或者是其他條件表達(dá)式的判斷。今天我們就說(shuō)一下關(guān)于數(shù)字的判斷。
我們的數(shù)字可能存放在定義好的一個(gè)變量中,也可能從是某個(gè)集合的長(zhǎng)度,也可能是某個(gè)方法返回的信息。這里就討論一下某個(gè)方法的返回信息。
假定存在下面的一個(gè)方法,返回值是一個(gè)List<int>
- static List<int> GetIntList()
- {
- Console.WriteLine("第 {0} 進(jìn)入GetIntList方法",Counter);
- Counter++;
- return new List<int>(){
- 1,2,3,4,5};
- }
需要對(duì)這個(gè)方法的返回結(jié)果進(jìn)行循環(huán)處理,剛開(kāi)始大多數(shù)都會(huì)這么寫(xiě),以for循環(huán)為例。
- for (int i = 0; i < GetIntList().Count; i++)
- {
- }
后來(lái)知道的多了一些,或者是聽(tīng)到別人說(shuō),經(jīng)過(guò)自己的驗(yàn)證。發(fā)現(xiàn)這個(gè)循環(huán)判斷條件有問(wèn)題,每次判斷都會(huì)重新調(diào)用GetIntList方法,造成極大地浪費(fèi)。就會(huì)修改成下面的樣子。
- int len=GetIntList().Count;
- for (int i = 0; i < len; i++)
- {
- }
先定義一個(gè)變量,保存集合的長(zhǎng)度。
經(jīng)過(guò)驗(yàn)證,while…do、do…while也存在類似的問(wèn)題,也需要注意。
有時(shí)候我們需要做的就是對(duì)集合里面的每個(gè)元素進(jìn)行處理,我們會(huì)選用foreach這個(gè)便利的循環(huán)結(jié)構(gòu),因?yàn)樗挥每紤]下標(biāo)越界的問(wèn)題。從上面的驗(yàn)證結(jié)果看,就會(huì)有人說(shuō)下面的代碼有問(wèn)題。
- foreach (int i in GetIntList())
- {
- }
到底有沒(méi)有問(wèn)題呢?需要驗(yàn)證。
- using System;
- using System.Collections.Generic;
- using System.Linq;
- using System.Text;
- using System.Data.Common;
- using System.Configuration;
- using MongoDB.Driver;
- using AutoTest.ServiceLocator;
- using System.Reflection;
- using AutoTest.Common;
- namespace AutoTest
- {
- class Program
- {
- static void Main(string[] args)
- {
- Console.WriteLine("------------------------------Begin------------------------------");
- Console.WriteLine("Foreach循環(huán)");
- Counter = 1;
- foreach (int i in GetIntList())
- {
- }
- Console.WriteLine("For循環(huán)");
- Counter = 1;
- for (int i = 0; i < GetIntList().Count; i++)
- {
- }
- Console.WriteLine("do...while...循環(huán)");
- Counter =1;
- int num=0;
- do
- {
- num++;
- }
- while (num < GetIntList().Count );
- Console.WriteLine("while...do...循環(huán)");
- Counter = 1;
- num=0;
- while (num < GetIntList().Count)
- {
- num++;
- };
- Console.WriteLine("------------------------------End------------------------------");
- Console.ReadKey();
- }
- static int Counter=1;
- static List<int> GetIntList()
- {
- Console.WriteLine("第 {0} 進(jìn)入GetIntList方法",Counter);
- Counter++;
- return new List<int>(){
- 1,2,3,4,5};
- }
- }
- }
其實(shí)經(jīng)過(guò)驗(yàn)證,發(fā)現(xiàn),foreach不同于其他三個(gè)循環(huán)結(jié)構(gòu),是不會(huì)發(fā)生重復(fù)的GetIntList方法調(diào)用的。
結(jié)論
1、foreach和其他三個(gè)循環(huán)結(jié)構(gòu)不太一樣。
2、需要用事實(shí)說(shuō)話。
【編輯推薦】