• 多线程什么时候该加锁?


    1 .加锁、解锁(同步/互斥)是多线程中非常基本的操作,但我却看到不少的代码对它们处理的很不好。简单说来有三类问题,一是加锁范围太大,虽然避免了逻辑错误,但锁了不该锁的东西,难免降低程序的效率;二是该锁的不锁,导致各种莫名其妙的错误;三是加锁方式不合适,该用临界区的用内核对象等,也会降低程序的效率。

    要正确的运用锁操作,首先要弄清楚什么时候需要加锁。一般可能“同时发生多个写操作”或“同时发生读写操作”时,必需要加Lock.

    2,NET警惕匿名方法造成变量共享 http://www.csharpwin.com/csharpspace/8200r3812.shtml

    此类问题也不光会出现在匿名方法中。如果您使用Lambda表达式创建了一个表达式树,其中也用到了一个“局部变量”,那么表达式树在解析或执行时同样也会获取“当前”的值,而不是创建表达式树时的值。

    即:Linq中使用List.AsParallel()

     //账单所包含的订单总重。此时会导致未知的错误!!


    可能同一时间有线程A在返回Weigh(读),另一线程B进行Sum计算;产生多线程同时读写操作。 

    decimal orderTotalWeight = order7.AsParallel().Sum(m => bllOrderInfo.GetProductCodeWeight(m.Code) * m.Quantity).ToDecimal();

           /// <summary>
            /// 根据产品编号获取重量。
            /// </summary>
            /// <param name="productCode"></param>
            /// <returns></returns>
            public decimal GetProductCodeWeight(string productCode)
            {

                    . .. . .

                   ...........

                   return result;
            }

    共享数据个人理解的是全局变量,多个线程同时访问全局变量会导致不可预知的错误!

    例如:

    private int m_Count;

    public void  Calc()

    {

        int count;

        count++;

        lock()

        {

           m_Count++;

        }

    }
     

  • 相关阅读:
    【python-leetcode295-双堆】数据流的中位数
    python数组二分查找算法bisect
    python堆队列算法heapq
    python中的容器序列类型collections
    step(iter)、epoch、batch size之间的关系
    【python-leetcode437-树的深度遍历】路径总和Ⅲ
    Java 代码实现POST/GET请求
    .NET 按格式导出txt
    java fastjson解析json字符串
    Java 对象转XML xStream 别名的使用 附下载方式
  • 原文地址:https://www.cnblogs.com/51net/p/3080205.html
Copyright © 2020-2023  润新知