博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Stopwatch类学习
阅读量:5952 次
发布时间:2019-06-19

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

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

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

using System;

namespace System.Diagnostics{

    public class Stopwatch:
   {
   }
}
是不是一目了然!
 
3、类属性介绍
下面是Stopwatch类的所有的属性以及属性的用法以及每个属性会配上一段代码实例来阐述这个属性到底是怎么用的:
 
Elapsed     表示当前实例(线程)测量出的总运行时间
public TimeSpan Elapsed{get;}   //该属性只读
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;

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

代码如下:

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

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()

 
 
 

 

转载于:https://www.cnblogs.com/GreenLeaves/p/6344356.html

你可能感兴趣的文章
Rust 1.27支持SIMD
查看>>
“10%时间”:优点和缺点——敏捷海滩会议上Elizabeth Pope的报告
查看>>
关于“Fluent UI”或Ribbon Design报道的补充说明
查看>>
2018年终盘点:“年度爆款”的区块链真的结束了吗?
查看>>
51信用卡 Android自动埋点实践
查看>>
敏捷现状10周年调查
查看>>
PHP Session可能会引起并发问题
查看>>
AI产品开发的核心原则:以研究为核心驱动
查看>>
大规模集群中Docker镜像如何分发管理?试试Uber刚开源的Kraken
查看>>
WinDocks发布Windows版本的Docker引擎
查看>>
完美解决html中select的option不能隐藏的问题。
查看>>
推荐5大开源工具,用于开发Kubernetes项目
查看>>
制定2015年的移动开发策略
查看>>
JPA 2.2改进了易用性
查看>>
从蚂蚁金服实践入手,带你深入了解 Service Mesh
查看>>
24周年,“常青树”Delphi发布新版本10.3.1
查看>>
7. 从数据库获取数据- 从零开始学Laravel
查看>>
阿里百川码力APP监控 来了!
查看>>
使用dotenv管理环境变量
查看>>
温故js系列(11)-BOM
查看>>