一疹启、概念
什么是線程
一個線程要執(zhí)行任務(wù),必須得有線程
一個進程(程序)的所有任務(wù)都在線程中執(zhí)行的
一個線程執(zhí)行任務(wù)是串行的,也就是說一個線程,同一時間內(nèi),只能執(zhí)行一個任務(wù)
多線程原理
同一時間,CPU只能處理1條線程,只有一條線程在工作(執(zhí)行)
多線程并發(fā)(同時)執(zhí)行,其實質(zhì)是CPU快速的在多線程之間調(diào)度(切換)
如果線程過多,會怎樣?
CPU在N多條線程中調(diào)度,會消耗大量的cpu資源
每條線程被調(diào)度執(zhí)行的頻率越低(線程的執(zhí)行效率低)
多線程的優(yōu)點
能適當提高程序的執(zhí)行效率
能適當提高資源的利用率(CPU 內(nèi)存利用率等)
多線程的缺點
創(chuàng)建線程是有開銷的,iOS下主要成本包括:內(nèi)核數(shù)據(jù)結(jié)構(gòu)(大約1KB)润梯、棧空間(子線程512KB髓介、主線程1MB十籍,也可以使用-setStackSize:設(shè)置,但必須是4K的倍數(shù)杀糯,而且最小是16K),創(chuàng)建線程大約需要90毫秒的創(chuàng)建時間
如果開啟大量的線程,會降低程序的性能
程序越多CPU的線程上的開銷就越大
程序設(shè)計更加復(fù)雜:線程之間的通訊,多線程的數(shù)據(jù)共享
主線程的主要作用
顯示和刷新UI界面
處理UI事件(比如點擊事件,滾動事件,拖拽事件等)
主線程的使用注意
別將比較耗時的操作放在主線程中,會導(dǎo)致UI界面的卡頓
將耗時操作放在子線程(后臺線程,非主線程)
二苍苞、多線程的4種方案
三固翰、常見多線程面試題:
下面這些是我在不同時間不同地點喜歡問的Java線程問題。我沒有提供答案羹呵,但只要可能我會給你線索骂际,有些時候這些線索足夠回答問題。
1.現(xiàn)在有T1冈欢、T2歉铝、T3三個線程,你怎樣保證T2在T1執(zhí)行完后執(zhí)行凑耻,T3在T2執(zhí)行完后執(zhí)行太示?
這個線程問題通常會在第一輪或電話面試階段被問到,目的是檢測你對”join”方法是否熟悉香浩。這個多線程問題比較簡單类缤,可以用join方法實現(xiàn)。
2.在Java中Lock接口比synchronized塊的優(yōu)勢是什么弃衍?你需要實現(xiàn)一個高效的緩存呀非,它允許多個用戶讀,但只允許一個用戶寫镜盯,以此來保持它的完整性岸裙,你會怎樣去實現(xiàn)它?
lock接口在多線程和并發(fā)編程中最大的優(yōu)勢是它們?yōu)樽x和寫分別提供了鎖速缆,它能滿足你寫像ConcurrentHashMap這樣的高性能數(shù)據(jù)結(jié)構(gòu)和有條件的阻塞降允。Java線程面試的問題越來越會根據(jù)面試者的回答來提問。我強烈建議在你去參加多線程的面試之前認真讀一下Locks艺糜,因為當前其大量用于構(gòu)建電子交易終統(tǒng)的客戶端緩存和交易連接空間剧董。
3.在java中wait和sleep方法的不同?
通常會在電話面試中經(jīng)常被問到的Java線程面試問題破停。最大的不同是在等待時wait會釋放鎖翅楼,而sleep一直持有鎖。Wait通常被用于線程間交互真慢,sleep通常被用于暫停執(zhí)行毅臊。
4.用Java寫代碼來解決生產(chǎn)者——消費者問題。
與上面的問題很類似黑界,但這個問題更經(jīng)典管嬉,有些時候面試都會問下面的問題。在Java中怎么解決生產(chǎn)者——消費者問題朗鸠,當然有很多解決方法蚯撩,我已經(jīng)分享了一種用阻塞隊列實現(xiàn)的方法。有些時候他們甚至會問怎么實現(xiàn)哲學家進餐問題烛占。
5.你將如何使用thread dump胎挎?你將如何分析Thread dump?
在UNIX中你可以使用kill -3忆家,然后thread dump將會打印日志呀癣,在windows中你可以使用”CTRL+Break”。非常簡單和專業(yè)的線程面試問題弦赖,但是如果他問你怎樣分析它项栏,就會很棘手。
6.****用Java編程一個會導(dǎo)致死鎖的程序蹬竖,你將怎么解決沼沈?
這是我最喜歡的Java線程面試問題,因為即使死鎖問題在寫多線程并發(fā)程序時非常普遍币厕,但是很多侯選者并不能寫deadlock free code(無死鎖代碼列另?),他們很掙扎旦装。只要告訴他們页衙,你有N個資源和N個線程,并且你需要所有的資源來完成一個操作。為了簡單這里的n可以替換為2店乐,越大的數(shù)據(jù)會使問題看起來更復(fù)雜艰躺。通過避免Java中的死鎖來得到關(guān)于死鎖的更多信息。
7.你在多線程環(huán)境中遇到的共同的問題是什么眨八?你是怎么解決它的腺兴?
多線程和并發(fā)程序中常遇到的有Memory-interface、競爭條件廉侧、死鎖页响、活鎖和饑餓。問題是沒有止境的段誊,如果你弄錯了闰蚕,將很難發(fā)現(xiàn)和調(diào)試。這是大多數(shù)基于面試的连舍,而不是基于實際應(yīng)用的Java線程問題没陡。
8.為什么我們調(diào)用start()方法時會執(zhí)行run()方法,為什么我們不能直接調(diào)用run()方法烟瞧?
這是一個非常經(jīng)典的java多線程面試問題诗鸭。這也是我剛開始寫線程程序時候的困惑。現(xiàn)在這個問題通常在電話面試或者是在初中級Java面試的第一輪被問到参滴。這個問題的回答應(yīng)該是這樣的强岸,當你調(diào)用start()方法時你將創(chuàng)建新的線程,并且執(zhí)行在run()方法里的代碼砾赔。但是如果你直接調(diào)用run()方法蝌箍,它不會創(chuàng)建新的線程也不會執(zhí)行調(diào)用線程的代碼。
9.Java中的volatile關(guān)鍵是什么作用暴心?怎樣使用它妓盲?在Java中它跟synchronized方法有什么不同?
自從Java 5和Java內(nèi)存模型改變以后专普,基于volatile關(guān)鍵字的線程問題越來越流行悯衬。應(yīng)該準備好回答關(guān)于volatile變量怎樣在并發(fā)環(huán)境中確保可見性檀夹、順序性和一致性筋粗。
10.****什么是不可變對象,它對寫并發(fā)應(yīng)用有什么幫助炸渡?
另一個多線程經(jīng)典面試問題娜亿,并不直接跟線程有關(guān),但間接幫助很多蚌堵。這個java面試問題可以變的非常棘手买决,如果他要求你寫一個不可變對象沛婴,或者問你為什么String是不可變的。
面試指導(dǎo)相關(guān)部分已經(jīng)結(jié)束督赤,如果有朋友正準備面試嘁灯,但是對多線程并發(fā)這一塊理解不是很透徹可以加群:725219329.我錄制了一些面試針對多線程并發(fā)經(jīng)常容易碰到的難題與難點,還有多線程的底層原理等視頻够挂。有興趣的可以加入進來旁仿。最后提供一個非常全面的多線程并發(fā)學習路線圖藕夫。
四孽糖、多線程并發(fā)的學習思路:
史上最全面并發(fā)編程架構(gòu)體系
上圖是我從事Java開發(fā)工作以來總結(jié)歸納出最全面的多線程并發(fā)學習知識點,內(nèi)容看上去很多毅贮,很復(fù)雜办悟,其實學起來非常容易,我也會經(jīng)常在我的群里上傳一些關(guān)于分布式架構(gòu)滩褥,微服務(wù)架構(gòu)病蛉,源碼分析,JVM瑰煎,并發(fā)編程的學習視頻分享給進群的朋友而且每一個專題板塊都會有一個學習錄像圖铺然,如果各位有興趣的話可以加下我的群:725219329來免費學習。
五酒甸、總結(jié)
其實魄健,很多面試官都清楚,初級程序員對于多線程的掌握度幾乎為零插勤。但是面試環(huán)節(jié)中沽瘦,很多面試官都會抱著試一試的態(tài)度去提問一兩道多線程的題目。其目的不是為了難為面試者农尖,也不是為了彰顯面試的“高大上”析恋,而是為了區(qū)分一般人才與優(yōu)質(zhì)人才。最后一點大家謹記:
在找工作的時候盛卡,除了做些相關(guān)面試和準備熟悉以前做的項目之外助隧,還應(yīng)該學習新的知識。畢竟滑沧,每多學一點并村,成功找到工作的機會就大一點。而且嚎货,IT這行橘霎,技術(shù)發(fā)展過于快速,如果沒有學習新知識的動力殖属,終究會被淘汰姐叁。
因為學習實在是很枯燥無味。學習是一個長期投資,短期很難道看到收益外潜。所以學習這塊最好可以給自己定一個目標原环,每天學習一點,慢慢的會達到的处窥。如果沒有動力的話嘱吗,可以給自己設(shè)置獎勵。這是可以激發(fā)學習的興趣的滔驾。還有一點谒麦,今天能坐完的事情,絕對不要留給明天哆致。畢竟绕德,人都是有惰性的。你要相信你自己摊阀,今天的你能做的沒有做耻蛇,明天的你也不會做的。
我的博客即將搬運同步至騰訊云+社區(qū)胞此,邀請大家一同入駐:https://cloud.tencent.com/developer/support-plan?invite_code=2atz56sczd7o8