某个API调用返回两个数组.
一个数组包含属性名称,例如
Properties[0] = "Heartbeat"
Properties[1] = "Heartbeat 2"
Properties[2] = "Some Other discovery method"
另一个数组包含Properties数组的值,例如
Values[0] = "22/01/2007"
Values[1] = "23/02/2007"
Values[2] = "5/06/2008"
值和属性数组元素匹配,例如,Values [0]始终是Properties [0]的值,等等.
我的目标是获得最新的“ Heartbeat *”值.请注意,心跳属性和值并不总是出现在数组的元素1和2中,因此我需要搜索它们.
代码如下:
static DateTime GetLatestHeartBeat(string[] Properties, string[] Values)
{
DateTime latestDateTime = new DateTime();
for(int i = 0; i < Properties.Length; i++)
{
if(Properties[i].Contains("Heart"))
{
DateTime currentDateTime;
DateTime.TryParse(Values[i],out currentDateTime);
if (currentDateTime > LatestDateTime)
latestDateTime = currentDateTime;
}
}
return latestDateTime
}
上面的代码给了我想要的结果,唯一的问题是在没有更多的心跳值找到之后循环继续.是否有更有效的方法来执行以上操作?
解决方法:
我会在parallel for loop中找到包含“ Heart”(或其他关键字)的索引来加快速度.然后遍历这些索引以找到最新的索引.
static DateTime GetLatestHeartBeat(string[] props, string[] vals)
{
ConcurrentBag<int> heartIndxs = new ConcurrentBag<int>();
// find the indices of "Heart" in parallel
Parallel.For(0, props.Length,
index =>
{
if (props[index].Contains("Heart"))
{
heartIndxs.Add(index);
}
});
// loop over each heart index to find the latest one
DateTime latestDateTime = new DateTime();
foreach (int i in heartIndxs)
{
DateTime currentDateTime;
if (DateTime.TryParse(vals[i], out currentDateTime) && (currentDateTime > latestDateTime))
latestDateTime = currentDateTime;
}
return latestDateTime;
}
如果使用DateTime.TryParse确实太慢,则可以使用RegEx解析日期字符串并进行自己的比较.老实说,我不确定这是否比使用DateTime.TryParse更快.这是对该主题的讨论:Which is Quicker: DateTime.TryParse or Regex