即使在使用Parallel.Foreach

时间:2018-05-16 15:22:58

标签: c# object concurrency task-parallel-library parallel.foreach

我正在尝试批量创建对象(> 4000),这需要超过8秒。

allrowslist<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"]],
  });
});

请建议。

1 个答案:

答案 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}");
}