DataRow锁分配

时间:2016-02-04 10:47:42

标签: c# asp.net multithreading datarow

我有一个巨大的Parallel.For循环。问题是DataRow写操作不是多线程的,所以我需要锁定assign语句。这对我来说不是问题,只是当我必须锁定所有赋值操作时,它看起来很难看。它看起来像这样:

Parallel.For(0, ds.Tables["MyTable"].Rows.Count, i =>
lock (s_lockObject)
{
    ds.Tables["MyTable"].Rows[i]["myValue1"] = myValue1;
}
//some operations

lock (s_lockObject)
{
    ds.Tables["MyTable"].Rows[i]["myValue2"] = myValue2;
}

//some operations
lock (s_lockObject)
{
    ds.Tables["MyTable"].Rows[i]["myValue3"] = myValue3;
}
});

默认情况下,有一种方法可以锁定赋值,例如写一些扩展名。

1 个答案:

答案 0 :(得分:0)

如果要删除重复的代码,可以提取赋值DataRow值的函数。例如:

    public static class DataTableExtensions
    {
        public static void SetCellValue<T>(this DataTable table, int row, string col, T value)
        {
           lock (table)
           {
              table.Rows[row][col] = value;
           }
        }
    }