我正在尝试批量创建对象(> 4000
),这需要超过8秒。
allrows
是list<object[]>
,有4000条记录。
ConcurrentBag <data> lstdata = new ConcurrentBag <data>();
Parallel.ForEach(allRows, (row) => {
lstdata.Add(new data() {
Id = row["NB"],
ColumnId = row["COLUMN_ID"]],
Value = row["VALUE"]],
});
});
请建议。
答案 0 :(得分:-1)
由于需要采取锁定,并行可能不会更快。
尝试使用可枚举的ctor
List<SimpleClass> simpleClassList = new List<SimpleClass>() { new SimpleClass(1, "bob"), new SimpleClass(2, "ken") };
var x = from t in simpleClassList
select new SimpleClass (t.ID + 10, t.Name);
ConcurrentBag<SimpleClass> simpleClassCB = new ConcurrentBag<SimpleClass>(x);
foreach (var v in simpleClassCB)
{
Debug.WriteLine($"{v.ID} {v.Name}");
}