首頁 後端開發 php教程 (转)趣文:小弟我是一个线程

(转)趣文:小弟我是一个线程

Jun 13, 2016 pm 12:29 PM
cpu nbsp

(转)趣文:我是一个线程

来自:码农翻身(微信号:coderising)

作者:IBM刘欣  

我是一个线程, 我一出生就被编了个号: 0x3704,  然后被领到一个昏暗的屋子里,  这里我发现了很多和我一模一样的同伴。

我身边的同伴0x6900 待的时间比较长, 他带着沧桑的口气对我说:

我们线程的宿命就是处理包裹。 把包裹处理完以后还得马上回到这里,否则可能永远回不来了。

 

我一脸懵懂,包裹,什么包裹?

”不要着急,马上你就会明白了, 我们这里是不养闲人的。“

果然,没多久,屋子的门开了, 一个面貌凶恶的家伙吼道: 

"0x3704 ,出来!"

我一出来就被塞了一个沉甸甸的包裹,上面还有附带着一个写满了操作步骤的纸。 

"快去,把这个包裹处理了。"

"去哪儿处理"

"跟着指示走, 先到就绪车间"

果然,地上有指示箭头,跟着它来到了一间明亮的大屋子,这里已经有不少线程了, 大家都很紧张,好像时刻准备着往前冲。

我刚一进来,就听见广播说:“0x3704, 进入车间”

我赶紧往前走, 身后很多人议论说:

 ”他太幸运了, 刚进入就绪状态就能运行“

 ”是不是有关系?“ 

 ”不是,你看人家的优先级多高啊, 唉“

前边就是车间, 这里简直是太美了, 怪不得老线程总是唠叨着说:要是能一直待在这里就好了。 

这里空间大,视野好,空气清新,鸟语花香,还有很多从来没见过的人,像服务员一样等着为我服务。 

他们也都有编号, 更重要的是每个人还有个标签,上面写着:硬盘,数据库,内存,网卡...

我现在理解不了,看看操作步骤吧:

 

第一步:从包裹中取出参数  

 

打开包裹, 里边有个HttpRequest  对象, 可以取到 userName, password两个参数

 

第二步:执行登录操作

 

奥,原来是有人要登录啊,我把userName/password 交给 数据库服务员,他拿着数据, 慢腾腾的走了。  

他怎么这么慢? 不过我是不是正好可以在车间里多待一会儿? 反正也没法执行第三步。

就在这时,车间里的广播响了: 

"0x3704,  我是CPU , 记住你正在执行的步骤, 马上带包裹离开"

我慢腾腾的开始收拾

”快点, 别的线程马上就要进来了“ 

离开这个车间, 又来到一个大屋子,这里很多线程慢腾腾的在喝茶,打牌。

”哥们,你们没事干了?“ 

”你新来的把, 你不知道我在等数据库服务员给我数据啊! ,据说他们比我们慢好几十万倍, 在这里好好歇吧“

”啊? 这么慢?  我这里有人在登录系统, 能等这么长时间吗"

”放心,你没听说过人间一天, CPU一年吗, 我们这里是用纳秒,毫秒计时的, 人间等待一秒,相当于我们好几天呢, 来的及“

干脆睡一会吧 , 不知道过了多久 ,大喇叭又开始广播了:

"0x3704, 你的数据来了,快去执行”

我转身就往CPU车间跑,发现这里的们只出不进!

后面传来阵阵哄笑声:

”果然是新人, 不知道还得去就绪车间等“

于是赶紧到就绪车间, 这次没有那么好运了, 等了好久才被再次叫进CPU车间。

在等待的时候, 我听见有人小声议论:

”听说了吗,最近有个线程被kill掉了“

”为啥啊?“

”这家伙赖在CPU车间不走, 把CPU利用率一直搞成100%,后来就被kill掉了“

”Kill掉以后弄哪儿去了“

”可能被垃圾回收了吧“

我心里打了个寒噤 ,  赶紧接着处理, 收下的动作块多了,第二步登录成功了

 

第三步:构建登录成功后的主页

 

这一步有点费时间, 因为有很多HTML需要处理, 不知道代码谁写的,处理起来很烦人。

我正在紧张的制作html呢, CPU有开始叫了:

"0x3704,  我是CPU , 记住你正在执行的步骤, 马上带包裹离开"

”为啥啊“

”每个线程只能在CPU上运行一段时间,到了时间就得让别人用了, 你去就绪车间待着, 等着叫你吧“

就这样, 我一直在就绪-运行 这两个状态,不知道轮转了多少次, 终于安装步骤清单把工作做完了。

最后顺利的把包含html的包裹发了回去。

至于登录以后干什么事儿 , 我就不管了。 

 

马上就要回到我那昏暗的房间了, 真有点舍不得这里。 

不过相对于有些线程, 我还是幸运的, 他们运行完以后就彻底的销毁了,而我还活着 !

回到了小黑屋, 老线程0x6900 问:

 

”怎么样?第一天有什么感觉?“

”我们的世界规则很复杂 , 首先你不知道什么时候会被挑中执行;  第二 ,在执行的过程中随时可能被打断,让出CPU车间;

 第三,一旦出现硬盘,数据库这样耗时的操作也得让出CPU,去等待;  第四,就是数据来了,你也不一定马上执行,还得等着CPU挑选“

 

”小伙子理解的不错啊“

”我不明白为什么很多线程都执行完就死了, 为什么咱们还活着?“

”你还不知道, 长生不老是我们的特权, 我们这里有个正式的名称,叫做 线程池!“

 

平淡的日子就这么一天天过去, 作为一个线程, 我每天的生活都是取包裹,处理包裹,然后回到我们昏暗的家:线程池。

有一天我回来的时候, 听到有个兄弟说, 今天要好好休息下,明天就是最疯狂的一天。 

我看了一眼日历,明天是 11月11号 。 

 

果然,零点刚过,不知道那些人类怎么了, 疯狂的投递包裹, 为了应付蜂拥而至的海量包裹, 线程池里没有一个人能闲下来,全部出去处理包裹,CPU车间利用率超高,硬盘在嗡嗡转, 网卡疯狂的闪,  即便如此, 还是处理不完,堆积如山。

我们也没有办法,实在是太多太多了, 这些包裹中大部分都是浏览页面,下订单,买,买,买。

不知道过了多久, 包裹山终于慢慢的消失了。

终于能够喘口气, 我想我永远都不会忘记这一天。

通过这个事件,我明白了我所处的世界:这是一个电子商务的网站!

我每天的工作就是处理用户的登录,浏览, 购物车,下单,付款。

 

我问线程池的元老0x6900 : " 我们要工作到什么时候?"

" 要一直等到系统重启的那一刻", 0x6900 说

" 那你经历过系统重启吗?"

" 怎么可能? , 系统重启就是我们的死亡时刻, 也就是世界末日,一旦重启, 整个线程池全部销毁,时间和空间全部消失,一切从头再来”

" 那什么时候会重启?"

" 这就不好说了,好好享受眼前的生活吧....."

 

其实生活丰富多彩, 我最喜欢的包裹是上传图片,由于网络慢,所以能在就绪车间, CPU车间待很长很长时间,可以认识很多好玩的线程。

比如说上次认识了memecached 线程,他给我说通过他缓存了很多的用户数据, 还是分布式的! 很多机器上都有!

我说怪不得后来的登录操作快了那么多, 原来是不再从数据库取数据了你那里就有啊, 哎对了你是分布式的你去过别的机器没有?

他说怎么可能我每次也只能通过网络往那个机器发送一个GET, PUT命令才存取数据而已, 别的一概不知。

 再比如说上次在等待的时候遇到了数据库连接的线程, 我才知道它他那里也是一个连接池, 和我们线程池几乎一模一样。

 他说有些包裹太变态了,竟然查看一年的订单数据, 简直把我累死了。

 我说拉倒吧你, 你那是纯数据, 你把数据传给我以后,我还得组装成HTML,  工作量不知道比你大多少倍。

 他说一定你要和memecached搞好关系,直接从他那儿拿数据,尽量少直接调用数据库, 我们JDBC connection也能活的轻松点。

 我说好啊好啊, 关键是你得提前把数据搞到缓存啊, 要不然我先问一遍缓存, 没有数据, 我这不还得找你吗?

 生活就是这样, 如果你自己不找点乐子,还有什么意思?

 有一天我遇到一个可怕的事情, 差一点死在外边,回不了线程池了......

其实这次遇险我应该能够预想到才对, 太大意了。 

 

前几天我处理过一些从http 发来的存款和取款的包裹, 老线程0x6900 特意嘱咐我:

 "处理这些包裹的时候要特别小心, 你得一定要先获得一把锁, 在对账户存款或者取款的时候一定要把账户给锁住, 要不然别的线程就会在你等待的时候趁虚而入,搞破坏, 我年轻那会儿很毛糙,就捅了篓子" 

 

为了“恐吓”我, 好心的0x6900还给了我两个表格:

1、没有加锁的情况

 

2、加锁的情况

 

我看的胆颤心惊, 原来不加锁会带来这么严重的事故。

从此以后看到存款,取款的包裹就倍加小心, 还好,没有出过事故。 

 今天我收到的一个包裹是转账, 从某著名演员的账号给某著名导演转钱, 具体是谁我就不透漏了, 数额可真是不小

 我按照老线程的吩咐, 肯定要加锁啊, 先对著名演员账号加锁, 在对著名导演账号加锁。

 可我万万没想到的是, 还有一个线程,对,就是0x7954,  竟然同时在从这个导演到往这个演员转账。 

 

于是乎,就出现了这么个情况:

 

刚开始我还不知道什么情况, 一直坐在等待车间傻等, 可是等的时间太长了, 长达几十秒 ! 我可从来没有经历过这样的事件。 

 这时候我就看到了线程0x7954 , 他悠闲的坐在那里喝咖啡, 我和他聊了起来:

“哥们, 我看你已经喝了8杯咖啡了, 怎么还不去干活?”

“你不喝了9杯茶了吗?” 0x7954 回敬到。

“我在等一个锁, 不知道哪个孙子一直不释放”

“我也在等锁啊,我要是知道哪个孙子不释放锁我非揍死他不可 ” 0x7954 毫不示弱。

 我偷偷的看了一眼, 这家伙怀里不就抱着我正在等的 某导演的锁嘛?

很明显, 0x7954 也发现了我正抱着他正在等待的锁。 

 

很快我们两个就吵了起来, 互不相让

 "把你的锁先给我, 让我先做完"

"不行, 从来都是做完工作才释放锁, 现在绝对不能给你"

 

从争吵到打起来, 就那么几秒钟的事儿。 

 更重要的是, 我们俩不仅仅持有这个著名导演和演员的锁, 还有很多其他的锁, 导致等待的线程越来越多, 围观的人们把屋子都挤满了。 

最后事情真的闹大了, 我从来没见过终极大boss "操作系统" 也来了。 

大Boss毕竟是见多识广, 他看了一眼, 哼了一声 , 很不屑的说:

 "又出现死锁了"

"你们俩要Kill掉一个, 来吧, 过来抽签 "

 

这一下子把我给吓尿了, 这么严重啊!

我战战兢兢的抽了签,打开一看, 是个"活"字。 

唉,小命终于保住了。 

 

可怜的0x7954 被迫交出了所有的资源以后, 很不幸的被kill掉, 消失了。 

我拿到了导演的锁, 可以开始干活了。

大Boss操作系统如一阵风似的消失了, 身后只传来他的声音:

记住, 我们这里导演>演员,  无论认识情况都要先获得导演的锁

由于不仅仅是只有导演和演员, 还有很多其他人, Boss留下了一个表格,  里边是个算法, 用来计算资源的大小, 计算出来以后,永远按照从大到小的方式来获得锁:

 


 

我回到线程池, 大家都知道了我的历险, 围着我问个不停。 

凶神恶煞的线程调度员把大Boss的算法贴到了墙上。 

每天早上, 我们都得像无节操的房屋中介, 美容美发店的服务员一样, 站在门口,像被耍猴一样大声背诵:

"多个资源加锁要牢记, 一定要按Boss的算法比大小, 然后从最大的开始加锁"

 

--------------------------------------------------------

又过了很多天, 我和其他线程们发现了一个奇怪的事情:包裹的处理越来越简单

不管任何包裹,不管是登录, 浏览,存钱..... 处理的步骤都是一样的, 返回一个固定的html页面

 

有一次我偷偷的看了一眼, 上面写着:

"本系统将于今晚 00:00 至4:00 进行维护升级, 给你带来的不便我们深感抱歉"

我去告诉了老线程0x6904,  他叹了一口气说:

"唉, 我们的生命也到头了, 看来马上就要重启系统, 我们就要消失了, 再见吧兄弟。"

系统重启的那一刻终于到来了。 

我看到屋子里的东西一个个的不见了, 等待车间,就绪车间,甚至CPU车间都慢慢的消失了。

我身边的线程兄弟也越来越少, 最后只剩我自己了。 

我在空旷的原野上大喊: 还有人吗?

无人应答。

我们这一代线程池完成了使命。

下一代线程池将很快重生。

(完)

如果您阅读过此文章有所收获,请为我顶一个,如果文章中有错误的地方,欢迎指出。

相互学习,共同进步!

 

本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

AI Hentai Generator

AI Hentai Generator

免費產生 AI 無盡。

熱門文章

R.E.P.O.能量晶體解釋及其做什麼(黃色晶體)
1 個月前 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.最佳圖形設置
1 個月前 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.如果您聽不到任何人,如何修復音頻
1 個月前 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.聊天命令以及如何使用它們
1 個月前 By 尊渡假赌尊渡假赌尊渡假赌

熱工具

記事本++7.3.1

記事本++7.3.1

好用且免費的程式碼編輯器

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

禪工作室 13.0.1

禪工作室 13.0.1

強大的PHP整合開發環境

Dreamweaver CS6

Dreamweaver CS6

視覺化網頁開發工具

SublimeText3 Mac版

SublimeText3 Mac版

神級程式碼編輯軟體(SublimeText3)

在遊戲時,CPU利用率應該是多少? 在遊戲時,CPU利用率應該是多少? Feb 19, 2024 am 11:21 AM

遊戲因消耗大量資源而導致電腦運作速度變慢是常見現象。了解遊戲時CPU的使用率是至關重要的,這樣可以避免過度負荷。因此,掌握適當的CPU使用率是維持遊戲體驗流暢的關鍵。在本文中,我們將探討遊戲執行時間CPU應該達到的適當使用率。遊戲時的CPU使用率CPU使用率是指衡量處理器工作負載的重要指標,取決於CPU的效能規格。功率較大的CPU通常具有更高的使用率。擁有更多核心和執行緒的CPU可以提高系統的整體效能。多執行緒支援有助於充分發揮CPU的潛力。在遊戲中,CPU使用率取決於處理器的使用率,這會影響遊戲

Win11如何設定CPU效能全開 Win11如何設定CPU效能全開 Feb 19, 2024 pm 07:42 PM

許多使用者在使用Win11系統時發現電腦運作不夠流暢,想要提升CPU效能,但不清楚如何操作。以下將詳細介紹如何在Win11系統中設定CPU效能至最高,讓您的電腦更有效率。設定方法:1、右鍵點選桌面上的”此電腦”,選擇選項清單中的”屬性”。 2、進入到新的介面後,點選”相關連結”中的”高級系統設定”。 3、在開啟的視窗中,點選上方中的」進階」選項卡,接著點選」效能」下方中的&

如何使用Intel XTU對CPU進行欠壓與超頻 如何使用Intel XTU對CPU進行欠壓與超頻 Feb 19, 2024 am 11:06 AM

英特爾XTU是一款強大的應用程序,可讓您輕鬆管理電腦的效能。您可以透過調整CPU電壓來解決過熱問題,或透過超頻來提升效能。在這篇文章中,我們將探討如何利用英特爾XTU來最佳化電腦的效能,無論是調整電壓或進行超頻。欠壓和超頻對CPU有什麼作用?在我們繼續學習如何對CPU進行欠壓和超頻之前,首先必須了解它們是什麼。欠電壓指的是逐漸降低CPU所需的電壓。這個過程有助於減少熱量排放,因為高電壓會導致更高的溫度。透過減少CPU的電壓供應,可以有效降低溫度。如果筆記本在發熱後開始減速,應及時解決問題

cpu盒裝和散裝的區別 cpu盒裝和散裝的區別 Jan 23, 2024 am 09:46 AM

cpu盒裝和散裝的區別:1、品質;2、保固期;3、風扇;4、價格;5、包裝;6、銷售通路。詳細介紹:1、質量,無論是盒裝還是散裝,CPU本身的品質是沒有任何差別的,它們都由同一生產廠家製造,經過相同的品質測試和品質控制流程;2、保固期,盒裝CPU通常提供更長的保固期,一般為三年,而散裝CPU通常只有一年的保固期,這是因為盒裝CPU通常是由官方或授權的經銷商銷售的等等。

10種在 Windows 11 上調整亮度的方法 10種在 Windows 11 上調整亮度的方法 Dec 18, 2023 pm 02:21 PM

螢幕亮度是使用現代計算設備不可或缺的一部分,尤其是當您長時間注視螢幕時。它可以幫助您減輕眼睛疲勞,提高易讀性,並輕鬆有效地查看內容。但是,根據您的設置,有時很難管理亮度,尤其是在具有新UI更改的Windows11上。如果您在調整亮度時遇到問題,以下是在Windows11上管理亮度的所有方法。如何在Windows11上變更亮度[10種方式解釋]單一顯示器使用者可以使用下列方法在Windows11上調整亮度。這包括使用單一顯示器的桌上型電腦系統以及筆記型電腦。讓我們開始吧。方法1:使用操作中心操作中心是訪問

如何增加電腦CPU的時脈頻率 如何增加電腦CPU的時脈頻率 Feb 20, 2024 am 09:54 AM

電腦CPU如何超頻隨著科技的不斷進步,人們對於電腦效能的需求也越來越高。而一個有效的提升電腦效能的方法就是透過超頻(overclocking)來增加CPU的工作頻率。超頻可以使CPU更快地處理數據,從而提供更高的運算能力。那麼,電腦CPU如何超頻呢?以下將為大家介紹超頻的基本原理和具體操作方法。首先,讓我們來了解一下超頻的原理。 CPU的工作頻率是由主機板上的晶振

WIN10服務主機太佔cpu的處理操作過程 WIN10服務主機太佔cpu的處理操作過程 Mar 27, 2024 pm 02:41 PM

1.首先我們右鍵點選任務列空白處,選擇【任務管理器】選項,或右鍵開始徽標,然後再選擇【任務管理器】選項。 2.在開啟的任務管理器介面,我們點選最右邊的【服務】選項卡。 3.在開啟的【服務】選項卡,點選下方的【開啟服務】選項。 4.在開啟的【服務】窗口,右鍵點選【InternetConnectionSharing(ICS)】服務,然後選擇【屬性】選項。 5.在開啟的屬性窗口,將【開啟方式】修改為【禁用】,點選【應用程式】後點選【確定】。 6.點選開始徽標,然後點選關機按鈕,選擇【重啟】,完成電腦重啟就行了。

144 核心,3D 堆疊 SRAM:富士通詳細介紹下一代資料中心處理器 MONAKA 144 核心,3D 堆疊 SRAM:富士通詳細介紹下一代資料中心處理器 MONAKA Jul 29, 2024 am 11:40 AM

本站7月28日消息,根據外媒TechRader報道,富士通詳細介紹了計劃於2027年出貨的FUJITSU-MONAKA(以下簡稱MONAKA)處理器。 MONAKACPU基於「雲端原生3D眾核」架構,採用Arm指令集,面向資料中心、邊緣與電信領域,適用於AI運算,能實現大型主機層級的RAS1。富士通表示,MONAKA將在能源效率和性能方面實現飛躍:得益於超低電壓(ULV)製程等技術,該CPU可實現2027年競品2倍的能效,冷卻無需水冷;此外該處理器的應用性能也可達對手2倍。在指令方面,MONAKA配備的向量

See all articles