学习心得,为的是让新人能理解,高手直接绕~

lock 确保当一个线程位于代码的临界区时,另一个线程不进入临界区。如果其他线程试图进入锁定的代码,则它将一直等待(即被阻止),直到该对象被释放。

引用一句看到的资料里比较流行的话“前面说过,每个线程都有自己的资源,但是代码区是共享的,即每个线程都可以执行相同的函数。这可能带来的问题就是几个线程同时执行一个函数,导致数据的混乱,产生不可预料的结果,因此我们必须避免这种情况的发生。”

建一个控制台应用程序

首先引用这个.....

using System.Threading;

    class ThreadInterrupt
{
static void Main()
{
test tt = new test();
///写这么多个为的是让环境更加容易创造出氛围来,线程多起来,出问题的可能性就大
new Thread(new ThreadStart(tt.test1)).Start();
new Thread(new ThreadStart(tt.test1)).Start();
new Thread(new ThreadStart(tt.test1)).Start();
new Thread(new ThreadStart(tt.test1)).Start();
new Thread(new ThreadStart(tt.test1)).Start();
new Thread(new ThreadStart(tt.test1)).Start();
new Thread(new ThreadStart(tt.test1)).Start();
new Thread(new ThreadStart(tt.test1)).Start();
new Thread(new ThreadStart(tt.test1)).Start();
new Thread(new ThreadStart(tt.test1)).Start();
new Thread(new ThreadStart(tt.test1)).Start();
new Thread(new ThreadStart(tt.test1)).Start();
new Thread(new ThreadStart(tt.test1)).Start();
new Thread(new ThreadStart(tt.test1)).Start();
new Thread(new ThreadStart(tt.test1)).Start();
new Thread(new ThreadStart(tt.test1)).Start();
new Thread(new ThreadStart(tt.test1)).Start();
new Thread(new ThreadStart(tt.test1)).Start();
new Thread(new ThreadStart(tt.test1)).Start();
new Thread(new ThreadStart(tt.test1)).Start();
new Thread(new ThreadStart(tt.test1)).Start();
new Thread(new ThreadStart(tt.test1)).Start();
new Thread(new ThreadStart(tt.test1)).Start();
new Thread(new ThreadStart(tt.test1)).Start();
new Thread(new ThreadStart(tt.test1)).Start();
new Thread(new ThreadStart(tt.test1)).Start();
new Thread(new ThreadStart(tt.test1)).Start();
new Thread(new ThreadStart(tt.test1)).Start(); }
class test
{
private int a;
private object b;
public test()
{
a = ;
b = new object();
} public void test1()
{ //////在该位置加lock(this){ ///没有lock的情况下,所有线程都会实时进入(线程是无序的)
Console.WriteLine("the thread:{0} 进入 ...", Thread.CurrentThread.GetHashCode());
/////然后每个线程都会去判断a的值
if (a == )
{
Console.WriteLine("a={0},b={1},当前进程{2}", a, b, Thread.CurrentThread.GetHashCode());
return;
}
///到此,如果线程哈希值不是4,则休眠一秒钟,为的是让晚于线程4但是已经判断a!=0的线程再次停留,给线程4充分的事件去把a置为0
if (Thread.CurrentThread.GetHashCode() != )
{
Thread.Sleep();
}
/////用当前线程的哈希值除a,为的是如果a为0的话能出现异常,当然可以随便写 110/a,907867869/a都可以
b = (Thread.CurrentThread.GetHashCode() / a).ToString();
///每个线程进入时对a做一些改变,无关紧要的
a -= Thread.CurrentThread.GetHashCode();
///如果线程哈希值是4,则将a置为0。
if (Thread.CurrentThread.GetHashCode() == )
{
a = ;
} Console.WriteLine("a={0},b={1},当前进程{2}", a, b, Thread.CurrentThread.GetHashCode()); //////lock的 "}"
} } }

C#线程中LOCK的意义的更多相关文章

  1. 一个线程中lock用法的经典实例

    /* 该实例是一个线程中lock用法的经典实例,使得到的balance不会为负数 同时初始化十个线程,启动十个,但由于加锁,能够启动调用WithDraw方法的可能只能是其中几个 作者:http://h ...

  2. 理解C#的Lock语法意义

    一. 为什么要lock,lock了什么? 当我们使用线程的时候,效率最高的方式当然是异步,即各个线程同时运行,其间不相互依赖和等待.但当不同的线程都需要访问某个资源的时候,就需要同步机制了,也就是说当 ...

  3. c#初学-多线程中lock用法的经典实例

    本文转载自:http://www.cnblogs.com/promise-7/articles/2354077.html 一.Lock定义     lock 关键字可以用来确保代码块完成运行,而不会被 ...

  4. 多线程中lock用法的经典实例

    多线程中lock用法的经典实例 一.Lock定义     lock 关键字可以用来确保代码块完成运行,而不会被其他线程中断.它可以把一段代码定义为互斥段(critical section),互斥段在一 ...

  5. 线程高级应用-心得5-java5线程并发库中Lock和Condition实现线程同步通讯

    1.Lock相关知识介绍 好比我同时种了几块地的麦子,然后就等待收割.收割时,则是哪块先熟了,先收割哪块. 下面举一个面试题的例子来引出Lock缓存读写锁的案例,一个load()和get()方法返回值 ...

  6. Python进阶(3)_进程与线程中的lock(线程中互斥锁、递归锁、信号量、Event对象、队列queue)

    1.同步锁 (Lock) 当全局资源(counter)被抢占的情况,问题产生的原因就是没有控制多个线程对同一资源的访问,对数据造成破坏,使得线程运行的结果不可预期.这种现象称为“线程不安全”.在开发过 ...

  7. C#中的线程(中)-线程同步

    1.同步要领 下面的表格列展了.NET对协调或同步线程动作的可用的工具:                       简易阻止方法 构成 目的 Sleep 阻止给定的时间周期 Join 等待另一个线程 ...

  8. .NET中lock的使用方法及注意事项

    lock就是把一段代码定义为临界区,所谓临界区就是同一时刻只能有一个线程来操作临界区的代码,当一个线程位于代码的临界区时,另一个线程不能进入临界区,如果试图进入临界区,则只能一直等待(即被阻止),直到 ...

  9. Python并发编程之谈谈线程中的“锁机制”(三)

    大家好,并发编程 进入第三篇. 今天我们来讲讲,线程里的锁机制. 本文目录 何为Lock( 锁 )?如何使用Lock( 锁 )?为何要使用锁?可重入锁(RLock)防止死锁的加锁机制饱受争议的GIL( ...

随机推荐

  1. phpfpm和nginx设置开机自动启动

    ## 添加执行权限 chmod a+x /etc/init.d/nginx chmod a+x /etc/init.d/php-fpm ## 加入服务 chkconfig --add nginx ch ...

  2. 083. Remove Duplicates from Sorted List

    题目链接:https://leetcode.com/problems/rotate-list/description/ Given a sorted linked list, delete all d ...

  3. LeetCode.1137-第N个泰波那契数(N-th Tribonacci Number)

    这是小川的第409次更新,第441篇原创 看题和准备 今天介绍的是LeetCode算法题中Easy级别的第260题(顺位题号是1137).Tribonacci(泰波那契)序列Tn定义如下: 对于n&g ...

  4. python高级 之(三) --- 高阶函数

    高阶函数 map函数 简介 """ map(func,*iterables) 参数:一个是函数.一个是序列 作用:将序列中的元素依此作用于函数,将函数运行结果返回 存放于 ...

  5. mariadb数据库集群

    1.主从架构: 每个从节点需要一个dump线程连接主节点 异步:效率高,安全性低,有延迟 同步:效率低,安全性高,无延迟 主:可读可写,(dump thread) 从:可读不可写 (sql threa ...

  6. 【linux杂谈】查看centOS系统的版本号和内核号

    因为种种原因,我们通常需要查看centOS系统的版本号和内核号. 这里以centOS 6为切入点,展示了几种查看版本号和内核号的方法,同时也验证了其在centOS 7上的可行性. 一.centOS 6 ...

  7. SolidWorks学习笔记7 镜像,阵列

    镜像 将特征,面,实体相对于一个平面来复制.修改原来的特征,镜像特征随之改变 阵列 线性阵列 , 在左侧,先激活要阵列的特征,然后点击小柱 然后选择方向1和方向2,该方向的阵列距离和数量(一般使用边线 ...

  8. luoguP1352没有上司的舞会(树形DP)

    题目链接:https://www.luogu.org/problemnew/show/P1352 题意:给定n个结点,每个结点有一个权值,给n-1条边,n个结点构成一棵树.并且规定一个结点的父结点如果 ...

  9. 结合docker做flask+kafka数据接口与压力测试

    一.需求 需要做实时数据接入的接口.数据最终要写入库,要做到高并发,数据的完整,不丢失数据. 二.技术选型 1.因为只是做简单的接口,不需要复杂功能,所以决定用flask这个简单的python框架(因 ...

  10. 一些通用的js工具类,添加自定义插件

    common_t.js /** * 通用工具组件 对原有的工具进行封装,自定义某方法统一处理<br> * ^_^ * * Author: em.D * Date: 2016-05-17 * ...