具体的な例が見つからないので、質問を投稿しています。助けていただければ幸いです。
私は2つの大きな一般的なリストを持っており、どちらも30万を超えるアイテムがあります。
最初のリストをループして情報をプルバックし、新しいリストの新しいアイテムをその場で生成していますが、2番目のリスト内を検索し、3つの一致基準に基づいて値を返す必要があります。リストですが、ご想像のとおり、これを300k*300k回実行するには時間がかかります。
これをより効率的に行う方法はありますか?
私のコード:
var reportList = new List<StocksHeldInCustody>();
foreach (var correctDepotHolding in correctDepotHoldings)
{
var reportLine = new StocksHeldInCustody();
reportLine.ClientNo = correctDepotHolding.ClientNo;
reportLine.Value = correctDepotHolding.ValueOfStock;
reportLine.Depot = correctDepotHolding.Depot;
reportLine.SEDOL = correctDepotHolding.StockCode;
reportLine.Units = correctDepotHolding.QuantityHeld;
reportLine.Custodian = "Unknown";
reportLine.StockName = correctDepotHolding.StockR1.Trim() + " " + correctDepotHolding.StockR2.Trim();
//Get custodian info
foreach (var ccHolding in ccHoldList)
{
if (correctDepotHolding.ClientNo != ccHolding.ClientNo) continue;
if (correctDepotHolding.Depot != ccHolding.Depot) continue;
if (correctDepotHolding.StockCode != ccHolding.StockCode) continue;
if (correctDepotHolding.QuantityHeld != ccHolding.QuantityHeld) continue;
reportLine.Custodian = ccHolding.Custodian;
break;
}
reportList.Add(reportLine);
}