为什么我的堆栈跟踪缺少步骤?

时间:2015-11-17 13:59:02

标签: c# .net stack-trace

我记录的堆栈跟踪似乎缺少一步。

private void StartLoadingResources(DataService separateDataService)
{
    ...
    batchResource.Resources.Add(key, new List<string>());
    // batchResource.Resources is the Dictionary object involved
    ...
}

为什么堆栈跟踪从StartLoadingResources直接转移到Insert(缺少Add步骤)?

System.AggregateException: One or more errors occurred. ---> System.ArgumentException: An item with the same key has already been added.
   at System.Collections.Generic.Dictionary`2.Insert(TKey key, TValue value, Boolean add)
   at MyApp.Importer.StartLoadingResources(DataService separateDataService) in ****\MyApp\MyApp\Importer.cs:line 313
   at MyApp.Importer.<Execute>b__5() in ****\MyApp\MyApp\Importer.cs:line 142
   at System.Threading.Tasks.Task.Execute()
   --- End of inner exception stack trace ---
   at System.Threading.Tasks.Task.Wait(Int32 millisecondsTimeout, CancellationToken cancellationToken)
   at System.Threading.Tasks.Task.Wait()
   at MyApp.Importer.Execute() in ****\MyApp\MyApp\Importer.cs:line 157
   at MyApp.Program.Execute() in ****\MyApp\MyApp\Program.cs:line 252
   at MyApp.Program.Main(String[] args) in ****\MyApp\MyApp\Program.cs:line 47
---> (Inner Exception #0) System.ArgumentException: An item with the same key has already been added.
   at System.Collections.Generic.Dictionary`2.Insert(TKey key, TValue value, Boolean add)
   at MyApp.Importer.StartLoadingResources(DataService separateDataService) in ****\MyApp\MyApp\Importer.cs:line 313
   at MyApp.Importer.<Execute>b__5() in ****\MyApp\MyApp\Importer.cs:line 142
   at System.Threading.Tasks.Task.Execute()<---

代码编译为Debug,未选中Build options中的“Optimize code”。

1 个答案:

答案 0 :(得分:1)

Dictionary<TKey, TValue>上的Add方法只调用Insert,因为它是1行方法,编译器只是简单地内联该方法调用,因为即使没有启用优化,它也是如此微不足道。