测试单线程与多线程的操作效率

static void Main(string[] args)
{
//需要建立个计时器计算出单线程和多线程那个效率更高
Stopwatch sw = new Stopwatch();

1使用传统方式即单线程(实验证明此方法用了219毫秒)
//sw.Start();
//ff1();
//ff2();
//sw.Stop();
//Console.WriteLine(sw.Elapsed.Milliseconds);
//2使用多线程(实验证明此方法用了290毫秒,其原因在于程序只有一个窗口在线程一进行时线程2就只好排队切换就花费了大量的时间)
//自定义委托
ThreadStart ts = new ThreadStart(ff1);
Thread tr = new Thread(ts);

ThreadStart ts2 = new ThreadStart(ff2);
Thread tr2 = new Thread(ts2);
sw.Start();
tr.Start();
tr2.Start();
//进程什么时候结束呢?这时就需要起一个循环实时判断进程的状态
while (true)
{
if (tr.ThreadState == System.Threading.ThreadState.Stopped && tr.ThreadState == System.Threading.ThreadState.Stopped)
{
sw.Stop();
Console.WriteLine(sw.Elapsed.Milliseconds);
break;
}
}

Console.ReadKey();
}
//注意这里的方法要是静态的(线程需要也许是有待考证?)
private static void ff1()
{
for (int i = 0; i < 200; i++)
{
Console.WriteLine(i);
}
}
private static void ff2()
{
for (int i = 0; i < 200; i++)
{
Console.WriteLine("我是"+i);
}
}

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值