在我们的应用程序中,我们使用
Windows性能计数器来存储我们的一些应用程序指标,这些指标稍后会在某些Web服务中检索.
我遇到了从计数器读取值所花费的时间问题.我已经浏览了我的应用程序的其余部分,一切都很好,性能明智,但从循环中的计数器(从列表或数组)读取需要花费大量的时间.
示例代码:
// This triggers a read of the counter's initial value (1000ms delay following for calculated counters) counters.ToList().ForEach(counter => counter.NextValue());
在我对上面的循环的测试中,1,359个计数器的列表需要20秒,并且使用秒表,似乎读取计数器值的平均时间是0-10ms,或大约80-90ms.其中很多都需要0ms,最高约为170ms,平均非零值约为80-90ms.
也许我太乐观了,但我认为读取1,000个数值应该只需要几毫秒.这里有更多的处理工作比我知道的还要多吗?
我实际上在我的逻辑中有另一个循环,它获得计算计数器的第二个值.这只会使情况变得更糟.