上厕所想到的线程同步

2024-02-04 04:58
文章标签 线程 同步 厕所 想到

本文主要是介绍上厕所想到的线程同步,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

    作为一个程序员,每天都是喝水2小时,搬砖10分钟的,这不,刚喝完水,准备搬点砖了。

    众所周知,人在大量饮水的情况下,是会频繁上卫生间的,无论肾的好与坏。喝点水就想往厕所跑,这是惯出来的。

    公司在去卫生间的路上有一道门,这道门呢,关上了就锁住了,得输入密码才能打开;如果不锁呢,也没关系,上完厕所再关也可以;但是呢,一旦锁上门了,再打开就要输入密码,花费一点时间,而且门呢,这一开一关会产生电磁铁吸住-释放的声音,有点吵。

    平时一个人上厕所,关不关门都无所谓,我尿完了,回来顺手就可以关上;但是其他同事也要上厕所,人上完了,不关门,我待会回去可以关上,但是呢,他要是回去顺手把门一锁,我就得输入密码,“咔咔”的开门-关门,挺安静的一层楼被整得贼吵。

    现将上厕所这一场景抽象出来,小便池属于公共资源上厕所的人为线程门为锁(内核对象的公共资源,每次只有一个线程能拿到,那么公司的这道门自然就不是了,上大号的那道门才是),占用小便池就是业务处理时间,以下梳理整体流程:

    首先,suppose 公司的这道门平时都是打开的,一旦关闭,就无法从外面打开进入,只有小便完的人出来了,才能打开这道门,然后其他人才能进去。

    接着,我准备去卫生间了。这个时候门是开着的,表明没有人在占用小便池。当我进门的时候,我反手关上门了(获得锁了)。从外面看的话,同事看到门被锁上了,知道有人在上厕所,就不会进去了,只能坐在工位上多喝点水了。那么我呢,就可以去厕所撒尿了。对了,先洗手,再撒尿,尿完了,再洗手,就是这么讲究,就是这么prevent from病从口入。那么撒尿要多久呢,要看喝了多少水,咱们公司在29L,厕所这可以看到窗外的一大片马路,一般我会在这看一会来往的车流,美女是没有的,顺便照下镜子,看看今天的发量是否和昨天一样。待确认之后,就出卫生间洗手了,洗完手要甩两下(风干机是没有的)。好了,这下就要从一个短暂的通道回到刚刚关闭的门这了,现在,我要输入密码开门了(打开这个锁)。随着“咔咔”的声音响起,门开了。同事这会已经瞟向我这边了,水喝完了吗?(喝水的时间就是在等待,线程是由操作系统来分配调度的,当下一个时间片分给同事了,他就可以上厕所了)。当我走出来了的时候,他没跟我打招呼的就大踏步的进去了,顺便反手锁了门。此时,我又该喝我的水了,不是,是写我的这个段子了……

    

    

 

这篇关于上厕所想到的线程同步的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/676403

相关文章

Springboot的ThreadPoolTaskScheduler线程池轻松搞定15分钟不操作自动取消订单

《Springboot的ThreadPoolTaskScheduler线程池轻松搞定15分钟不操作自动取消订单》:本文主要介绍Springboot的ThreadPoolTaskScheduler线... 目录ThreadPoolTaskScheduler线程池实现15分钟不操作自动取消订单概要1,创建订单后

详谈redis跟数据库的数据同步问题

《详谈redis跟数据库的数据同步问题》文章讨论了在Redis和数据库数据一致性问题上的解决方案,主要比较了先更新Redis缓存再更新数据库和先更新数据库再更新Redis缓存两种方案,文章指出,删除R... 目录一、Redis 数据库数据一致性的解决方案1.1、更新Redis缓存、删除Redis缓存的区别二

C语言线程池的常见实现方式详解

《C语言线程池的常见实现方式详解》本文介绍了如何使用C语言实现一个基本的线程池,线程池的实现包括工作线程、任务队列、任务调度、线程池的初始化、任务添加、销毁等步骤,感兴趣的朋友跟随小编一起看看吧... 目录1. 线程池的基本结构2. 线程池的实现步骤3. 线程池的核心数据结构4. 线程池的详细实现4.1 初

Java子线程无法获取Attributes的解决方法(最新推荐)

《Java子线程无法获取Attributes的解决方法(最新推荐)》在Java多线程编程中,子线程无法直接获取主线程设置的Attributes是一个常见问题,本文探讨了这一问题的原因,并提供了两种解决... 目录一、问题原因二、解决方案1. 直接传递数据2. 使用ThreadLocal(适用于线程独立数据)

Nacos集群数据同步方式

《Nacos集群数据同步方式》文章主要介绍了Nacos集群中服务注册信息的同步机制,涉及到负责节点和非负责节点之间的数据同步过程,以及DistroProtocol协议在同步中的应用... 目录引言负责节点(发起同步)DistroProtocolDistroSyncChangeTask获取同步数据getDis

基于MySQL Binlog的Elasticsearch数据同步实践

一、为什么要做 随着马蜂窝的逐渐发展,我们的业务数据越来越多,单纯使用 MySQL 已经不能满足我们的数据查询需求,例如对于商品、订单等数据的多维度检索。 使用 Elasticsearch 存储业务数据可以很好的解决我们业务中的搜索需求。而数据进行异构存储后,随之而来的就是数据同步的问题。 二、现有方法及问题 对于数据同步,我们目前的解决方案是建立数据中间表。把需要检索的业务数据,统一放到一张M

服务器集群同步时间手记

1.时间服务器配置(必须root用户) (1)检查ntp是否安装 [root@node1 桌面]# rpm -qa|grep ntpntp-4.2.6p5-10.el6.centos.x86_64fontpackages-filesystem-1.41-1.1.el6.noarchntpdate-4.2.6p5-10.el6.centos.x86_64 (2)修改ntp配置文件 [r

线程的四种操作

所属专栏:Java学习        1. 线程的开启 start和run的区别: run:描述了线程要执行的任务,也可以称为线程的入口 start:调用系统函数,真正的在系统内核中创建线程(创建PCB,加入到链表中),此处的start会根据不同的系统,分别调用不同的api,创建好之后的线程,再单独去执行run(所以说,start的本质是调用系统api,系统的api

java线程深度解析(六)——线程池技术

http://blog.csdn.net/Daybreak1209/article/details/51382604 一种最为简单的线程创建和回收的方法: [html]  view plain copy new Thread(new Runnable(){                @Override               public voi

java线程深度解析(五)——并发模型(生产者-消费者)

http://blog.csdn.net/Daybreak1209/article/details/51378055 三、生产者-消费者模式     在经典的多线程模式中,生产者-消费者为多线程间协作提供了良好的解决方案。基本原理是两类线程,即若干个生产者和若干个消费者,生产者负责提交用户请求任务(到内存缓冲区),消费者线程负责处理任务(从内存缓冲区中取任务进行处理),两类线程之