我的编程空间,编程开发者的网络收藏夹
学习永远不晚

C#中Stopwatch的使用及说明

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

C#中Stopwatch的使用及说明

C# Stopwatch的使用

什么是Stopwatch

Stopwatch:提供一组方法和属性,可以准确的测量运行时间。

使用的时候需要引用命名空间:System.Diagnostics。

Stopwatch的简单使用

//创建Stopwatch实例
Stopwatch sw = new Stopwatch();
//开始计时
sw.Start();
for (int i = 0; i < 100; i++)
{
  Console.WriteLine(i);
}
//停止计时
sw.Stop();
Console.WriteLine("用时:" + sw.ElapsedMilliseconds + "");
//重置 停止时间间隔测量,并将运行时间重置为0
sw.Reset();
Console.WriteLine("用时:" + sw.ElapsedMilliseconds + "");
//重启 停止时间间隔测量,并将运行时间重置为0,然后重新开始测量运行时间
sw.Restart();
for (int i = 0; i < 100; i++)
{
  Console.WriteLine(i);
}
sw.Stop();
//获取当前实例测量得出的总运行时间(以毫秒为单位)
Console.WriteLine("用时:" + sw.ElapsedMilliseconds + "");
//获取当前实例测量得出的总运行时间
Console.WriteLine("用时:"+sw.Elapsed); 
//获取当前实例测量得出的总运行时间(用计时器刻度表示)。
Console.WriteLine(sw.ElapsedTicks);
Console.Read();
//使用StartNew,相当于已经实例化并且启动计时
Stopwatch sw=Stopwatch.StartNew();
for (int i = 0; i < 100; i++)
{
  Console.WriteLine(i);
}
sw.Stop();
//获取当前实例测量得出的总运行时间(以毫秒为单位)
Console.WriteLine("用时:" + sw.ElapsedMilliseconds + "");
//获取当前实例测量得出的总运行时间
Console.WriteLine("用时:"+sw.Elapsed); 
Console.Read();

C#使用Stopwatch精确测量运行时间

一般测量时间间隔使用的是DateTime.Now实例的DateTime.Ticks当前属性,想要精确测量一个操作的运行时间就只能使用Stopwatch类计时了。

Stopwatch计时精度取决于硬件,如果安装的硬件和操作系统支持高分辨率性能计数器, 则Stopwatch类将使用该计数器来测量运行时间。否则,Stopwatch类将使用系统计时器来测量运行时间。

测量耗时操作的运行时间

            Stopwatch stopWatch = new Stopwatch();
            stopWatch.Start();
            Thread.Sleep(5000); // 耗时操作
            stopWatch.Stop();
            

            // 将经过的时间作为TimeSpan值
            TimeSpan ts = stopWatch.Elapsed;
            // 格式和显示时间值
            string elapsedTime = String.Format("{0:00}:{1:00}:{2:00}.{3:000}-{4:000}", ts.Hours, ts.Minutes, ts.Seconds, ts.Milliseconds, (ts.Ticks * 100 / 1000)%1000);
            Console.WriteLine("RunTime " + elapsedTime);

            // 将经过的时间作为毫秒数
            long mSeconds = stopWatch.ElapsedMilliseconds;
            Console.WriteLine("RunTime(ms) " + mSeconds);

            // 获取经过时间的计时器刻度
            // 也可在耗时操作前后使用Stopwatch.GetTimestamp()各获取1个Ticks值,然后相减得到耗时操作花费的计时器刻度
            // 计时器采用的计时方式不同,tick的时间单位不同
            long tick = stopWatch.ElapsedTicks;
            Console.WriteLine("RunTime(tick) " + tick);

            if (Stopwatch.IsHighResolution)
            {
                // 计时器刻度是高性能计时器滴答数
                Console.WriteLine("使用系统高分辨率性能计数器计时:");
                Console.WriteLine("  RunTime(ns) " +tick* ((1000L * 1000L * 1000L)/ Stopwatch.Frequency));
            }
            else
            {
                // 计时器刻度是DateTime.Now实例的DateTime.Ticks当前属性
                Console.WriteLine("使用DateTime类计时:");
                Console.WriteLine("  RunTime(ns) " + tick * 100);
            }

查看Stopwatch计时器的计时方式

        /// <summary>
        /// 显示计时器属性
        /// </summary>
        public static void DisplayTimerProperties()
        {
            // 显示定时器频率和分辨率
            if (Stopwatch.IsHighResolution)
            {
                Console.WriteLine("操作使用系统高分辨率性能计数器计时");
            }
            else
            {
                Console.WriteLine("操作使用DateTime类计时");
            }

            long frequency = Stopwatch.Frequency;
            Console.WriteLine("  计时器频率,单位为每秒滴答数 = {0}",
                frequency);
            long nanosecPerTick = (1000L * 1000L * 1000L) / frequency;
            Console.WriteLine("  计时器分辨率为 {0} 纳秒/滴答",
                nanosecPerTick);
        }

附上官网上的一个测试实例

        private static void TimeOperations()
        {
            long nanosecPerTick = (1000L * 1000L * 1000L) / Stopwatch.Frequency;
            const long numIterations = 10000;

            // 定义操作标题名称
            String[] operationNames = {"操作: Int32.Parse(\"0\")",
                                           "操作: Int32.TryParse(\"0\")",
                                           "操作: Int32.Parse(\"a\")",
                                           "操作: Int32.TryParse(\"a\")"};
            Console.WriteLine();
            Console.WriteLine("注:1ticks=100ns,1s=1000ms,1ms=1000us,1us=1000ns");

            // 从字符串解析整数的四种不同实现
            for (int operation = 0; operation <= 3; operation++)
            {
                // 定义操作统计的变量
                long numTicks = 0;
                long numRollovers = 0;
                long maxTicks = 0;
                long minTicks = Int64.MaxValue;
                int indexFastest = -1;
                int indexSlowest = -1;
                long milliSec = 0;

                Stopwatch time10kOperations = Stopwatch.StartNew();

                // 运行当前操作10001次。
                // 第一次执行时间将被丢弃,因为它可能会扭曲平均时间。
                for (int i = 0; i <= numIterations; i++)
                {
                    long ticksThisTime = 0;
                    int inputNum;
                    Stopwatch timePerParse;

                    switch (operation)
                    {
                        case 0:
                            // 使用try-catch语句分析有效整数
                            // 启动新的秒表计时器
                            timePerParse = Stopwatch.StartNew();
                            try
                            {
                                inputNum = Int32.Parse("0");
                            }
                            catch (FormatException)
                            {
                                inputNum = 0;
                            }

                            // 停止计时器,并保存操作所用的计时ticks

                            timePerParse.Stop();
                            ticksThisTime = timePerParse.ElapsedTicks;
                            break;
                        case 1:                           
                            timePerParse = Stopwatch.StartNew();
                            if (!Int32.TryParse("0", out inputNum))
                            {
                                inputNum = 0;
                            }
                            timePerParse.Stop();
                            ticksThisTime = timePerParse.ElapsedTicks;
                            break;
                        case 2:                            
                            timePerParse = Stopwatch.StartNew();
                            try
                            {
                                inputNum = Int32.Parse("a");
                            }
                            catch (FormatException)
                            {
                                inputNum = 0;
                            }
                            timePerParse.Stop();
                            ticksThisTime = timePerParse.ElapsedTicks;
                            break;
                        case 3:                           
                            timePerParse = Stopwatch.StartNew();
                            if (!Int32.TryParse("a", out inputNum))
                            {
                                inputNum = 0;
                            }                            
                            timePerParse.Stop();
                            ticksThisTime = timePerParse.ElapsedTicks;
                            break;
                        default:
                            break;
                    }
                    // 跳过第一个操作的时间,以防它导致一次性性能下降。
                    if (i == 0)
                    {
                        time10kOperations.Reset();
                        time10kOperations.Start();
                    }
                    else
                    {
                        // 更新迭代1-10001的操作统计信息。
                        if (maxTicks < ticksThisTime)
                        {
                            indexSlowest = i;
                            maxTicks = ticksThisTime;
                        }
                        if (minTicks > ticksThisTime)
                        {
                            indexFastest = i;
                            minTicks = ticksThisTime;
                        }
                        numTicks += ticksThisTime;
                        if (numTicks < ticksThisTime)
                        {
                            // Keep track of rollovers.
                            numRollovers++;
                        }
                    }
                }

                // 显示10000次迭代的统计信息
                time10kOperations.Stop();
                milliSec = time10kOperations.ElapsedMilliseconds;

                Console.WriteLine();
                Console.WriteLine("{0} 统计:", operationNames[operation]);
                Console.WriteLine("  最慢时间:  第{0}/{1}次操作,时间为{2} ticks",
                    indexSlowest, numIterations, maxTicks);
                Console.WriteLine("  最快时间:  第{0}/{1}次操作,时间为{2} ticks",
                    indexFastest, numIterations, minTicks);
                Console.WriteLine("  平均时间:  {0} ticks = {1} ns",
                    numTicks / numIterations,
                    (numTicks * nanosecPerTick) / numIterations);
                Console.WriteLine("  {0} 次操作的总时间: {1} ms",
                    numIterations, milliSec);
            }
        }

总结

以上为个人经验,希望能给大家一个参考,也希望大家多多支持编程网。

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

C#中Stopwatch的使用及说明

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

C#中Stopwatch的使用及说明

这篇文章主要介绍了C#中Stopwatch的使用及说明,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
2023-02-25

C++中new的用法及说明

这篇文章主要介绍了C++中new的用法及说明,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
2022-11-13

C++中forauto的用法及说明

这篇文章主要介绍了C++中forauto的用法及说明,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
2023-02-25

js中的WebSocket使用及说明

WebSocket是一种实时、低延迟的通信协议,允许客户端与服务器之间双向数据交换,弥补了传统HTTP请求-响应模型的局限性。它具有实时通信、低延迟、双向通信和低开销的优点,广泛用于聊天、实时数据流、多人游戏、物联网和协作工具等应用场景。要使用WebSocket,需要建立连接,收发消息,并使用API管理连接,包括open、send、close、onmessage、onerror等方法和事件。
js中的WebSocket使用及说明
2024-04-02

vue3中Vant的使用及说明

这篇文章主要介绍了vue3中Vant的使用及说明,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
2023-01-16

PyTorch中grid_sample的使用及说明

这篇文章主要介绍了PyTorch中grid_sample的使用及说明,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
2023-02-01

Keras中Conv1D的使用及说明

这篇文章主要介绍了Keras中Conv1D的使用及说明,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
2022-12-15

c#中Invoke与BeginInvoke的用法及说明

这篇文章主要介绍了c#中Invoke与BeginInvoke的用法及说明,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
2023-01-28

C#中的Stopwatch如何使用

本篇内容主要讲解“C#中的Stopwatch如何使用”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“C#中的Stopwatch如何使用”吧!C# Stopwatch的使用什么是StopwatchS
2023-07-05

C#字符集编码的使用及说明

这篇文章主要介绍了C#字符集编码的使用及说明,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
2023-01-28

element中el-select的使用及说明

这篇文章主要介绍了element中el-select的使用及说明,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
2023-01-16

vue-jsonp的使用及说明

这篇文章主要介绍了vue-jsonp的使用及说明,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
2022-12-08

Pytorch中torch.cat()函数的使用及说明

这篇文章主要介绍了Pytorch中torch.cat()函数的使用及说明,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
2023-01-03

sql中的if和else使用及说明

目录sql中的if和elseIF表达式IF(expr1,expr2,expr3)IFNULL(expr1,expr2)IF ELSE 做为流程控制语句使用sql中的if和elsemysql的IF既可以作为表达式用,也可在存储过程中作为流程
2022-11-28

idea中Stash与Unstash的使用及说明

这篇文章主要介绍了idea中Stash与Unstash的使用及说明,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
2023-02-15

c++的virtual和override作用及说明

这篇文章主要介绍了c++的virtual和override作用及说明,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
2022-11-13

编程热搜

  • Python 学习之路 - Python
    一、安装Python34Windows在Python官网(https://www.python.org/downloads/)下载安装包并安装。Python的默认安装路径是:C:\Python34配置环境变量:【右键计算机】--》【属性】-
    Python 学习之路 - Python
  • chatgpt的中文全称是什么
    chatgpt的中文全称是生成型预训练变换模型。ChatGPT是什么ChatGPT是美国人工智能研究实验室OpenAI开发的一种全新聊天机器人模型,它能够通过学习和理解人类的语言来进行对话,还能根据聊天的上下文进行互动,并协助人类完成一系列
    chatgpt的中文全称是什么
  • C/C++中extern函数使用详解
  • C/C++可变参数的使用
    可变参数的使用方法远远不止以下几种,不过在C,C++中使用可变参数时要小心,在使用printf()等函数时传入的参数个数一定不能比前面的格式化字符串中的’%’符号个数少,否则会产生访问越界,运气不好的话还会导致程序崩溃
    C/C++可变参数的使用
  • css样式文件该放在哪里
  • php中数组下标必须是连续的吗
  • Python 3 教程
    Python 3 教程 Python 的 3.0 版本,常被称为 Python 3000,或简称 Py3k。相对于 Python 的早期版本,这是一个较大的升级。为了不带入过多的累赘,Python 3.0 在设计的时候没有考虑向下兼容。 Python
    Python 3 教程
  • Python pip包管理
    一、前言    在Python中, 安装第三方模块是通过 setuptools 这个工具完成的。 Python有两个封装了 setuptools的包管理工具: easy_install  和  pip , 目前官方推荐使用 pip。    
    Python pip包管理
  • ubuntu如何重新编译内核
  • 改善Java代码之慎用java动态编译

目录