博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
c#之循环效率
阅读量:7036 次
发布时间:2019-06-28

本文共 3750 字,大约阅读时间需要 12 分钟。

很多人在保存数据时候对于使用数组、集合等?然后遍历数据的时候是for、froeach?

下面我就写一个小例子进行测试看看,话不多说,直接用数据说话。

1.构建数据分别是数组、集合构建,数据类型分别是值类型、引用类型

public static List
ListData = new List
(); public static int[] ArrayData = new int[10000]; public static List
ListPople = new List
(); public static people[] ArrayPeople = new people[10000]; public class people{ public string Name { get; set; } public int Age { get;set } public int Sex { get; set; } }public static void InitData() { for (int i = 0, j = 10000; i < j; i++) { ListData.Add(i); ArrayData[i] = i; ListPople.Add(new people() { Age=i, Name="N"+i, Sex=1 }); ArrayPeople[i] = new people() { Age = i, Name = "N" + i, Sex = 1 }; } }
View Code

2.for

static void Main(string[] args)        {            System.Diagnostics.Stopwatch stopwatch = new System.Diagnostics.Stopwatch();            Console.WriteLine("值类型for (int i = 0; i < count; i++)");            stopwatch.Start();              for (int i = 0; i < ArrayData.Length; i++)            {                Console.WriteLine(ArrayData[i]);            }            stopwatch.Stop();            Console.WriteLine("值类型使用时间:"+ stopwatch.ElapsedTicks);            stopwatch.Reset();            Console.WriteLine("值类型for (int i = 0,j =count;i
View Code

1万数据

 

5万数据

3.foreach

static void Main(string[] args)        {            InitData();            System.Diagnostics.Stopwatch stopwatch = new System.Diagnostics.Stopwatch();            Console.WriteLine("值类型 foreach");            stopwatch.Start();            foreach (int i in ListData)            {                //Console.WriteLine(i);            }            stopwatch.Stop();            Console.WriteLine("值类型使用时间:" + stopwatch.ElapsedTicks);            stopwatch.Reset();            Console.WriteLine("引用类型 foreach");            stopwatch.Start();            foreach (var i in ListPople)            {                //Console.WriteLine(i.Name);            }            stopwatch.Stop();            Console.WriteLine("使用时间:" + stopwatch.ElapsedTicks);            stopwatch.Reset();            Console.ReadLine();        }
View Code

1万数据

5万数据

4.委托货其他方式

static void Main(string[] args)        {            InitData();            System.Diagnostics.Stopwatch stopwatch = new System.Diagnostics.Stopwatch();            Console.WriteLine("数值类型:Array.ForEach");            stopwatch.Start();            Array.ForEach
(ListData.ToArray(), (value)=>{ }); stopwatch.Stop(); Console.WriteLine("值类型使用时间:" + stopwatch.ElapsedTicks); stopwatch.Reset(); Console.WriteLine("引用类型:Array.ForEach"); stopwatch.Start(); Array.ForEach
(ListPople.ToArray(), (value) => { }); stopwatch.Stop(); Console.WriteLine("值类型使用时间:" + stopwatch.ElapsedTicks); stopwatch.Reset(); Console.WriteLine("数值类型:Parallel.ForEach"); stopwatch.Start(); Parallel.ForEach(ListData, (value) => {}); stopwatch.Stop(); Console.WriteLine("使用时间:" + stopwatch.ElapsedTicks); stopwatch.Reset(); Console.WriteLine("引用类型:Parallel.ForEach"); stopwatch.Start(); Parallel.ForEach(ListPople, (value) => { }); stopwatch.Stop(); Console.WriteLine("使用时间:" + stopwatch.ElapsedTicks); stopwatch.Reset(); Console.ReadLine(); }
View Code

1万数据

5万数据

没有对比就没有伤害,所以大家在项目中遇到这类问题,还是选择合适自己的方法进行......

转载于:https://www.cnblogs.com/kq123321/p/6489242.html

你可能感兴趣的文章
springmvc - SqlSession
查看>>
枚举在业务系统中的最佳使用方式
查看>>
mybatis 打印sql语句
查看>>
做一个好的程序猿
查看>>
传入参数方法,参数值变化
查看>>
Mongodb Sharding Cluster 三台
查看>>
ORACLE下删除当前用户下所有对象
查看>>
Spring boot with Oracle
查看>>
Alamofire4.x开源代码分析(二)请求参数和编码
查看>>
Android设计模式系列(10)--SDK源码之原型模式
查看>>
对象的共享
查看>>
android在线API地址
查看>>
Android APK反编译详解
查看>>
Actor, Reactor与Proactor模型
查看>>
Verson Magic problem
查看>>
Passcode
查看>>
TapKu Graph
查看>>
面试需要的基础知识-合并排序数组
查看>>
关于Unity 2018的实体组件系统(ECS)一
查看>>
Echarts---添加渐变功能
查看>>