前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >Stopwatch类学习

Stopwatch类学习

作者头像
郑小超.
发布2018-01-24 15:45:46
5250
发布2018-01-24 15:45:46
举报
文章被收录于专栏:GreenLeavesGreenLeaves

1、概述:给一条大MSDN的链接关于Stopwatch类最详细的教程 ,然后看着教程自己手动敲一边,加深映象,好记性不如烂键盘,哈哈,开个玩笑!

2、类位置:这个类在哪里,这个是重点,虽然C#IDE很强大,但是我们还是得简单的了解下。通过一段代码来说明:

代码语言:js
复制
using System;
namespace System.Diagnostics{
    public class Stopwatch:System.Object
   {
   }
}

是不是一目了然!

3、类属性介绍

下面是Stopwatch类的所有的属性以及属性的用法以及每个属性会配上一段代码实例来阐述这个属性到底是怎么用的:

Elapsed     表示当前实例(线程)测量出的总运行时间

public TimeSpan Elapsed{get;}   //该属性只读

代码语言:javascript
复制
using System;
using System.Threading;
using System.Diagnostics;
namespace Mulithreading{
    class StopwatchStudy{
        static void Main(string[] args){
           Stopwatch sw=new Stopwatch();
           sw.Start();//开始计时
           Thread.Sleep(3000);
           sw.Stop();//计时结束
           TimeSpan ts=sw.Elapsed;//获取当前实例(主线程)总共的运行时间
           string Elapsed=string.Format("{0:00}:{1:00}:{2:00}:{3:00}",ts.Hours,ts.Minutes,ts.Seconds,ts.Milliseconds);//转换成字符串"{0:00}"表示对应的变量值以2位显示
           Console.Write(Elapsed);
        }
    }
}

ElapsedMillseconds     获取当前实例(线程)的总运行时间(以毫秒为单位)    返回值类型为long;

代码语言:javascript
复制
using System;
using System.Threading;
using System.Diagnostics;
namespace Mulithreading
{
    class StopwatchStudy
    {
        static void Main(string[] args)
        {
            Stopwatch sw = new Stopwatch();
            sw.Start();//开始计时
            Thread.Sleep(3000);
            sw.Stop();//计时结束
            long ts = sw.ElapsedMilliseconds;
            Console.WriteLine(ts);
            sw.Restart();
            Thread.Sleep(2000);
            sw.Stop();
            long ts2 = sw.ElapsedMilliseconds;
            Console.WriteLine(ts2);
        }
    }
}

ElapsedTicks   一个只读长整型,表示当前实例测量得出的计时器刻度总数。

 isRunning    返回一个bool值表示计时器是否正在运行,同样也是只读

4、方法介绍

Start()      这里就不做代码演示了,最基础的

Stop()      上同

Rsest() 方法     停止时间间隔测量,将运行时间重置为0

代码如下:

代码语言:javascript
复制
using System;
using System.Threading;
using System.Diagnostics;
namespace Mulithreading
{
    class StopwatchStudy
    {
        static void Main(string[] args)
        {
            Stopwatch sw = new Stopwatch();
            sw.Start();//开始计时
            Thread.Sleep(3000);
            sw.Stop();//计时结束
            TimeSpan ts = sw.Elapsed;
            string Elapsed = string.Format("{0:00}:{1:00}:{2:00}:{3:00}", ts.Hours, ts.Minutes, ts.Seconds, ts.Milliseconds);
            Console.WriteLine(Elapsed);
            sw.Reset();//重置时间
            TimeSpan ts2 = sw.Elapsed;//获取重置之后的总运行时间
            string Elapsed1 = string.Format("{0:00}:{1:00}:{2:00}:{3:00}", ts2.Hours, ts2.Minutes, ts2.Seconds, ts2.Milliseconds);
            Console.WriteLine(Elapsed1);
        }
    }
}

ReStart()     重置时间之后在开始重新测量时间相当于ReSet之后在Start

代码语言:javascript
复制
using System;
using System.Threading;
using System.Diagnostics;
namespace Mulithreading
{
    class StopwatchStudy
    {
        static void Main(string[] args)
        {
            Stopwatch sw = new Stopwatch();
            sw.Start();//开始计时
            Thread.Sleep(3000);
            sw.Stop();//计时结束
            TimeSpan ts = sw.Elapsed;
            string Elapsed = string.Format("{0:00}:{1:00}:{2:00}:{3:00}", ts.Hours, ts.Minutes, ts.Seconds, ts.Milliseconds);
            Console.WriteLine(Elapsed);
            sw.Restart();
            Thread.Sleep(2000);
            sw.Stop();
            TimeSpan ts2 = sw.Elapsed;
            string Elapsed1 = string.Format("{0:00}:{1:00}:{2:00}:{3:00}", ts2.Hours, ts2.Minutes, ts2.Seconds, ts2.Milliseconds);
            Console.WriteLine(Elapsed1);
        }
    }
}

StartNew()      将运行时间设置为0,然后开始测量运行时间,也就是重新开始一个新的实例,通过类名调用(上面的其他例子都通过对象实例调用)

需要注意的是该方法是Stopwatch的静态方法

public static void StartNew()

本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
原始发表:2017-01-23 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档