C#中获取程序执行时间

C#中获取程序执行时间

在C#中,获取程序执行时间通常有以下几种方法:

1. 使用DateTime类

你可以在程序开始执行前获取当前时间,然后在程序结束时再次获取当前时间,通过这两个时间点计算程序执行时间。

cs 复制代码
using System;

class Program
{
    static void Main()
    {
        DateTime startTime = DateTime.Now;

        // 执行你的代码
        for (int i = 0; i < 1000000; i++)
        {
            // 示例:一个简单的循环
        }

        DateTime endTime = DateTime.Now;
        TimeSpan executionTime = endTime - startTime;

        Console.WriteLine("程序执行时间: " + executionTime.TotalMilliseconds + " 毫秒");
    }
}

2. 使用Stopwatch类

System.Diagnostics.Stopwatch类是测量时间的一种更精确的方法,特别是对于需要高精度计时的场景。

cs 复制代码
using System;
using System.Diagnostics;

class Program
{
    static void Main()
    {
        Stopwatch stopwatch = new Stopwatch();
        stopwatch.Start();

        // 执行你的代码
        for (int i = 0; i < 1000000; i++)
        {
            // 示例:一个简单的循环
        }

        stopwatch.Stop();
        Console.WriteLine("程序执行时间: " + stopwatch.ElapsedMilliseconds + " 毫秒");
    }
}

3. 使用Environment.TickCount或Environment.TickCount64(对于64位系统)

这种方法不如Stopwatch精确,但对于简单的性能测试或快速获取时间差也是可行的。

cs 复制代码
using System;

class Program
{
    static void Main()
    {
        int startTime = Environment.TickCount; // 或使用Environment.TickCount64对于64位系统以避免溢出

        // 执行你的代码
        for (int i = 0; i < 1000000; i++)
        {
            // 示例:一个简单的循环
        }

        int endTime = Environment.TickCount; // 或使用Environment.TickCount64对于64位系统以避免溢出
        int executionTime = endTime - startTime; // 注意:这将返回以毫秒为单位的整数,但不直接提供TimeSpan对象。

        Console.WriteLine("程序执行时间: " + executionTime + " 毫秒");
    }
}

总结:

对于大多数应用场景,推荐使用Stopwatch类,因为它提供了更高的精度和灵活性。如果你仅仅需要快速获取两个时间点之间的差异,并且不介意精度问题,那么使用DateTime类或Environment.TickCount/Environment.TickCount64也是可行的。选择哪种方法取决于你的具体需求和精度要求

相关推荐
精神病不行计算机不上班几秒前
[Java Web]Java Servlet基础
java·前端·servlet·html·mvc·web·session
玉木成琳5 分钟前
Taro + React + @nutui/nutui-react-taro 时间选择器重写
前端·react.js·taro
wanhengidc6 分钟前
高性价比云手机 多端同步
运维·服务器·科技·智能手机·云计算
lxh011311 分钟前
2025/12/17总结
前端·webpack
芳草萋萋鹦鹉洲哦11 分钟前
【elementUI】form表单rules没生效
前端·javascript·elementui
LYFlied13 分钟前
【每日算法】LeetCode 560. 和为 K 的子数组
前端·数据结构·算法·leetcode·职场和发展
.hopeful.14 分钟前
Docker——初识
服务器·docker·微服务·容器·架构
howcode14 分钟前
年度总结——Git提交量戳破了我的副业窘境
前端·后端·程序员
恋猫de小郭15 分钟前
OpenAI :你不需要跨平台框架,只需要在 Android 和 iOS 上使用 Codex
android·前端·openai
cccyi725 分钟前
高级I/O编程:从Select、Poll到Epoll的演进与Reactor服务器实现
服务器·c++·reactor