C# 用于准确地测量运行时间的Stopwatch中.Start 方法和Stopwatch.Stop 方法

本文主要是介绍C# 用于准确地测量运行时间的Stopwatch中.Start 方法和Stopwatch.Stop 方法,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

 

一、Stopwatch 类

        提供一组方法和属性,可用于准确地测量运行时间。

public class Stopwatch

        使用 Stopwatch 类来确定应用程序的执行时间。

// 使用 Stopwatch 类来确定应用程序的执行时间
using System.Diagnostics;
class Program
{static void Main(string[] args){ArgumentNullException.ThrowIfNull(args);Stopwatch stopWatch = new();stopWatch.Start();Thread.Sleep(10000);stopWatch.Stop();// Get the elapsed time as a TimeSpan value.TimeSpan ts = stopWatch.Elapsed;// Format and display the TimeSpan value.string elapsedTime = String.Format("{0:00}:{1:00}:{2:00}.{3:00}",ts.Hours, ts.Minutes, ts.Seconds,ts.Milliseconds / 10);Console.WriteLine("RunTime " + elapsedTime);}
}
//运行结果:
/*
RunTime 00:00:10.01*/
// 使用 Stopwatch 类来计算性能数据。
using System.Diagnostics;namespace StopWatchSample
{class OperationsTimer{public static void Main(string[] args){ArgumentNullException.ThrowIfNull(args);DisplayTimerProperties();Console.WriteLine();Console.WriteLine("Press the Enter key to begin:");Console.ReadLine();Console.WriteLine();TimeOperations();}public static void DisplayTimerProperties(){// Display the timer frequency and resolution.if (Stopwatch.IsHighResolution){Console.WriteLine("Operations timed using the system's high-resolution performance counter.");}else{Console.WriteLine("Operations timed using the DateTime class.");}long frequency = Stopwatch.Frequency;Console.WriteLine("  Timer frequency in ticks per second = {0}",frequency);long nanosecPerTick = (1000L * 1000L * 1000L) / frequency;Console.WriteLine("  Timer is accurate within {0} nanoseconds",nanosecPerTick);}private static void TimeOperations(){long nanosecPerTick = (1000L * 1000L * 1000L) / Stopwatch.Frequency;const long numIterations = 10000;// Define the operation title names.string[] operationNames = {"Operation: Int32.Parse(\"0\")","Operation: Int32.TryParse(\"0\")","Operation: Int32.Parse(\"a\")","Operation: Int32.TryParse(\"a\")"};// Time four different implementations for parsing// an integer from a string.for (int operation = 0; operation <= 3; operation++){// Define variables for operation statistics.long numTicks = 0;long numRollovers = 0;long maxTicks = 0;long minTicks = long.MaxValue;int indexFastest = -1;int indexSlowest = -1;Stopwatch time10kOperations = Stopwatch.StartNew();// Run the current operation 10001 times.// The first execution time will be tossed// out, since it can skew the average time.for (int i = 0; i <= numIterations; i++){long ticksThisTime = 0;int inputNum;Stopwatch timePerParse;switch (operation){case 0:// Parse a valid integer using// a try-catch statement.// Start a new stopwatch timer.timePerParse = Stopwatch.StartNew();try{inputNum = int.Parse("0");}catch (FormatException){inputNum = 0;}// Stop the timer, and save the// elapsed ticks for the operation.timePerParse.Stop();ticksThisTime = timePerParse.ElapsedTicks;break;case 1:// Parse a valid integer using// the TryParse statement.// Start a new stopwatch timer.timePerParse = Stopwatch.StartNew();if (!int.TryParse("0", out inputNum)){inputNum = 0;}// Stop the timer, and save the// elapsed ticks for the operation.timePerParse.Stop();ticksThisTime = timePerParse.ElapsedTicks;break;case 2:// Parse an invalid value using// a try-catch statement.// Start a new stopwatch timer.timePerParse = Stopwatch.StartNew();try{inputNum = int.Parse("a");}catch (FormatException){inputNum = 0;}// Stop the timer, and save the// elapsed ticks for the operation.timePerParse.Stop();ticksThisTime = timePerParse.ElapsedTicks;break;case 3:// Parse an invalid value using// the TryParse statement.// Start a new stopwatch timer.timePerParse = Stopwatch.StartNew();if (!int.TryParse("a", out inputNum)){inputNum = 0;}// Stop the timer, and save the// elapsed ticks for the operation.timePerParse.Stop();ticksThisTime = timePerParse.ElapsedTicks;break;default:break;}// Skip over the time for the first operation,// just in case it caused a one-time// performance hit.if (i == 0){time10kOperations.Reset();time10kOperations.Start();}else{// Update operation statistics// for iterations 1-10000.if (maxTicks < ticksThisTime){indexSlowest = i;maxTicks = ticksThisTime;}if (minTicks > ticksThisTime){indexFastest = i;minTicks = ticksThisTime;}numTicks += ticksThisTime;if (numTicks < ticksThisTime){// Keep track of rollovers.numRollovers++;}}}// Display the statistics for 10000 iterations.time10kOperations.Stop();long milliSec = time10kOperations.ElapsedMilliseconds;Console.WriteLine();Console.WriteLine("{0} Summary:", operationNames[operation]);Console.WriteLine("  Slowest time:  #{0}/{1} = {2} ticks",indexSlowest, numIterations, maxTicks);Console.WriteLine("  Fastest time:  #{0}/{1} = {2} ticks",indexFastest, numIterations, minTicks);Console.WriteLine("  Average time:  {0} ticks = {1} nanoseconds",numTicks / numIterations,(numTicks * nanosecPerTick) / numIterations);Console.WriteLine("  Total time looping through {0} operations: {1} milliseconds",numIterations, milliSec);}}}
}
//运行结果:
/*
Operations timed using the system's high-resolution performance counter.Timer frequency in ticks per second = 10000000Timer is accurate within 100 nanoseconds*/

1.Stopwatch.Start 方法

        开始或继续测量某个时间间隔的运行时间。

        前例中有示例。 

public void Start ();

2.Stopwatch.Stop 方法

        停止测量某个时间间隔的运行时间。

public void Stop ();

        前例中有示例。

这篇关于C# 用于准确地测量运行时间的Stopwatch中.Start 方法和Stopwatch.Stop 方法的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/634394

相关文章

Nginx安全防护的多种方法

《Nginx安全防护的多种方法》在生产环境中,需要隐藏Nginx的版本号,以避免泄漏Nginx的版本,使攻击者不能针对特定版本进行攻击,下面就来介绍一下Nginx安全防护的方法,感兴趣的可以了解一下... 目录核心安全配置1.编译安装 Nginx2.隐藏版本号3.限制危险请求方法4.请求限制(CC攻击防御)

python生成随机唯一id的几种实现方法

《python生成随机唯一id的几种实现方法》在Python中生成随机唯一ID有多种方法,根据不同的需求场景可以选择最适合的方案,文中通过示例代码介绍的非常详细,需要的朋友们下面随着小编来一起学习学习... 目录方法 1:使用 UUID 模块(推荐)方法 2:使用 Secrets 模块(安全敏感场景)方法

MyBatis-Plus通用中等、大量数据分批查询和处理方法

《MyBatis-Plus通用中等、大量数据分批查询和处理方法》文章介绍MyBatis-Plus分页查询处理,通过函数式接口与Lambda表达式实现通用逻辑,方法抽象但功能强大,建议扩展分批处理及流式... 目录函数式接口获取分页数据接口数据处理接口通用逻辑工具类使用方法简单查询自定义查询方法总结函数式接口

MySQL深分页进行性能优化的常见方法

《MySQL深分页进行性能优化的常见方法》在Web应用中,分页查询是数据库操作中的常见需求,然而,在面对大型数据集时,深分页(deeppagination)却成为了性能优化的一个挑战,在本文中,我们将... 目录引言:深分页,真的只是“翻页慢”那么简单吗?一、背景介绍二、深分页的性能问题三、业务场景分析四、

JAVA中安装多个JDK的方法

《JAVA中安装多个JDK的方法》文章介绍了在Windows系统上安装多个JDK版本的方法,包括下载、安装路径修改、环境变量配置(JAVA_HOME和Path),并说明如何通过调整JAVA_HOME在... 首先去oracle官网下载好两个版本不同的jdk(需要登录Oracle账号,没有可以免费注册)下载完

nginx -t、nginx -s stop 和 nginx -s reload 命令的详细解析(结合应用场景)

《nginx-t、nginx-sstop和nginx-sreload命令的详细解析(结合应用场景)》本文解析Nginx的-t、-sstop、-sreload命令,分别用于配置语法检... 以下是关于 nginx -t、nginx -s stop 和 nginx -s reload 命令的详细解析,结合实际应

C#连接SQL server数据库命令的基本步骤

《C#连接SQLserver数据库命令的基本步骤》文章讲解了连接SQLServer数据库的步骤,包括引入命名空间、构建连接字符串、使用SqlConnection和SqlCommand执行SQL操作,... 目录建议配合使用:如何下载和安装SQL server数据库-CSDN博客1. 引入必要的命名空间2.

Java中读取YAML文件配置信息常见问题及解决方法

《Java中读取YAML文件配置信息常见问题及解决方法》:本文主要介绍Java中读取YAML文件配置信息常见问题及解决方法,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要... 目录1 使用Spring Boot的@ConfigurationProperties2. 使用@Valu

Java 方法重载Overload常见误区及注意事项

《Java方法重载Overload常见误区及注意事项》Java方法重载允许同一类中同名方法通过参数类型、数量、顺序差异实现功能扩展,提升代码灵活性,核心条件为参数列表不同,不涉及返回类型、访问修饰符... 目录Java 方法重载(Overload)详解一、方法重载的核心条件二、构成方法重载的具体情况三、不构

SQL中如何添加数据(常见方法及示例)

《SQL中如何添加数据(常见方法及示例)》SQL全称为StructuredQueryLanguage,是一种用于管理关系数据库的标准编程语言,下面给大家介绍SQL中如何添加数据,感兴趣的朋友一起看看吧... 目录在mysql中,有多种方法可以添加数据。以下是一些常见的方法及其示例。1. 使用INSERT I