c# - 这是获得运行异步任务所需时间的最佳方式吗?

标签 c# async-await

我想知道执行我的异步任务需要多长时间,以便我可以改进执行时间。

请看测试方法并指教。测试背景:我想在给定 sAMACcountName 的情况下从 Active Directory 中找出用户帐户管理员。

[TestMethod]
public async Task GetManagerAsync_TestMethod()
{
    // connect to the Active Directory
    var serviceUsers = new User(@"LDAP://XXXXXXXXX", @"USER", "PASSWORD");

    // get the time before the start of operation
    var sTime = DateTime.Now;

    // perform the task
    var task = await serviceUsers.GetManagerAsync(@"sAMAccountName");

    // get the time after the operation
    var eTime = DateTime.Now;

    // get the time span between the start and end time
    TimeSpan taskRunTime = eTime - sTime;

    System.Diagnostics.Debug.WriteLine("Operation took {0} seconds", taskRunTime.TotalSeconds);

    Assert.IsNotNull(task);
 }

最佳答案

你应该使用 Stopwatch相反。

var stopwatch = Stopwatch.StartNew();
var task = await serviceUsers.GetManagerAsync(@"sAMAccountName");
stopwatch.Stop();

var elapsed = stopwatch.Elapsed;

它不仅在语义上更正确,而且更准确:

If the installed hardware and operating system support a high-resolution performance counter, then the Stopwatch class uses that counter to measure elapsed time. Otherwise, the Stopwatch class uses the system timer to measure elapsed time.

关于c# - 这是获得运行异步任务所需时间的最佳方式吗?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/27441303/

相关文章:

c# - 返回 IAsyncEnumerable<T> 但结果不进行流式传输的 API

c# - 捕获从异步 lambda 抛出的异常

javascript - 如何使用 async/await 正确编写此内容

c# - 无需等待即可调用异步方法 #2

c# - 如何使自定义对话框保持在其父级之上而不是在其他应用程序之上

c# - 为什么我可以使用集合初始值设定项和来自另一个类的私有(private)集合访问?

c# - 存储在内存中的int和对象一样吗?

c# - 删除与基于 View 的实体具有一对多关联的实体对象

c# - 如何避免扩展方法中出现 TaskCanceledException?

c# - 如何从 IOwinRequest 获取上传文件的集合?