當前位置:首頁 > 公眾號精選 > 架構(gòu)師社區(qū)
[導(dǎo)讀]最近在匯總面試題,但是我寫的這個版本不是背誦版,不是那種死記硬背刻板的答案。

你好,我是 yes。

最近在匯總面試題,但是我寫的這個版本不是背誦版,不是那種死記硬背刻板的答案。

我的本意是拋磚引玉,針對每個題目給出我自己的理解和解釋型的答案,然后背誦版本需要你們自行去總結(jié)和記憶。

因為八股文在面試中是一定要的,也就是該知道的題還是得知道的,而在理解的基礎(chǔ)上記憶會比較深刻,并且可以應(yīng)對一些變種問題。

但是不清楚這樣的形式是不是受歡迎,所以我暫時拿兩個題目先發(fā)出來看看反響。

所以如果覺得這樣的形式哪里不好,需要改進的話,請留言。

1.如果讓你設(shè)計一個 HashMap 如何設(shè)計?

這個問題我覺得可以從 HashMap 的一些關(guān)鍵點入手,例如 hash 函數(shù)、如何處理沖突、如何擴容。

可以先說下你對 HashMap 的理解。

比如:HashMap 無非就是一個存儲 格式的集合,使得通過 key 在 O(1) 的時間復(fù)雜下就能查找到 value。

基本原理就是將 key 經(jīng)過 hash 函數(shù)進行散列得到散列值,然后通過散列值對數(shù)組取模得到對應(yīng)的 index 。

所以 hash 函數(shù)很關(guān)鍵,不僅運算要快,還需要分布均勻,減少 hash 碰撞。

而因為輸入值是無限的,而數(shù)組的大小是有限的所以肯定會有碰撞,因此可以采用拉鏈法來處理沖突。

為了避免惡意的 hash 攻擊,當拉鏈超過一定長度之后可以轉(zhuǎn)為紅黑樹結(jié)構(gòu)。

當然超過一定的結(jié)點還是需要擴容的,不然碰撞就太嚴重了。

而普通的擴容會導(dǎo)致某次 put 延時較大,特別是 HashMap 存儲的數(shù)據(jù)比較多的時候,所以可以考慮和 redis 那樣搞兩個 table 延遲移動,一次可以只移動一部分。

不過這樣內(nèi)存比較吃緊,所以也是看場景來 trade off 了。

還有,最好使用之前預(yù)估準數(shù)據(jù)大小,避免頻繁的擴容。

基本上這樣答下來差不多了,HashMap 幾個關(guān)鍵要素都包含了,接下來就看面試官怎么問了。

可能會延伸到線程安全之類的問題,反正就照著 currentHashMap 的設(shè)計答。

其實有些題目看起來是問如何設(shè)計,實際上你就答你對這個東西是怎么理解的,把它原理和一些要點講一講這個題目就過了。

比如我上面說的預(yù)估準數(shù)據(jù)的大小,這種看起來和設(shè)計沒關(guān)系,但是可以讓面試官知道你對這種方面是敏感的就夠了。

所以有時候的“答非所問”是 OK 的,如果面試官覺得你答的方向不對,自然而然會提醒你,到時候你再接招就好了。

簡單地說,很多提問不是真的要死板的對著面試題而回答,因為面試官也只是籠統(tǒng)地問。

2.如果讓你設(shè)計一個線程池如何設(shè)計?

這種設(shè)計類問題還是一樣,先說下理解,表明你是知道這個東西的用處和原理的,然后開始 BB?;旧暇褪前凑宅F(xiàn)有的設(shè)計來說,再添加一些個人見解。

線程池講白了就是存儲線程的一個容器,池內(nèi)保存之前建立過的線程來重復(fù)執(zhí)行任務(wù),減少創(chuàng)建和銷毀線程的開銷,提高任務(wù)的響應(yīng)速度,并便于線程的管理。

我個人覺得如果要設(shè)計一個線程池的話得考慮池內(nèi)工作線程的管理、任務(wù)編排執(zhí)行、線程池超負荷處理方案、監(jiān)控等方面。

要將初始化線程數(shù)、核心線程數(shù)、最大線程池都暴露出來可配置,包括超過核心線程數(shù)的線程空閑消亡相關(guān)配置。

然后任務(wù)的存儲結(jié)構(gòu)也得可配置,可以是無界隊列也可以是有界隊列,也可以根據(jù)配置,分多個隊列來分配不同優(yōu)先級的任務(wù),也可以采用 stealing 的機制來提高線程的利用率。

再提供配置來表明此線程池是 IO 密集型還是 CPU 密集型來改變?nèi)蝿?wù)的執(zhí)行策略。

超負荷的方案可以有多種,包括丟棄任務(wù)、拒絕任務(wù)并拋出異常、丟棄最舊的任務(wù)或自定義等等。

至于監(jiān)控的話,線程池設(shè)計要埋好點,暴露出用于監(jiān)控的接口,如已處理任務(wù)數(shù)、待處理任務(wù)數(shù)、正在運行的線程數(shù)、拒絕的任務(wù)數(shù)等等信息。

我覺得基本上這樣答就差不多了,等著面試官的追問就好。

注意不需要跟面試官解釋什么叫核心線程數(shù)之類的,都懂的沒必要。

當然這種開放型問題還是仁者見仁智者見智,我這個不是標準答案,僅供參考。

建議把線程池相關(guān)的關(guān)鍵字都要說出來,表面你對線程池的內(nèi)部原理的理解是透徹的。


免責聲明:本文內(nèi)容由21ic獲得授權(quán)后發(fā)布,版權(quán)歸原作者所有,本平臺僅提供信息存儲服務(wù)。文章僅代表作者個人觀點,不代表本平臺立場,如有問題,請聯(lián)系我們,謝謝!

本站聲明: 本文章由作者或相關(guān)機構(gòu)授權(quán)發(fā)布,目的在于傳遞更多信息,并不代表本站贊同其觀點,本站亦不保證或承諾內(nèi)容真實性等。需要轉(zhuǎn)載請聯(lián)系該專欄作者,如若文章內(nèi)容侵犯您的權(quán)益,請及時聯(lián)系本站刪除。
換一批
延伸閱讀

9月2日消息,不造車的華為或?qū)⒋呱龈蟮莫毥谦F公司,隨著阿維塔和賽力斯的入局,華為引望愈發(fā)顯得引人矚目。

關(guān)鍵字: 阿維塔 塞力斯 華為

加利福尼亞州圣克拉拉縣2024年8月30日 /美通社/ -- 數(shù)字化轉(zhuǎn)型技術(shù)解決方案公司Trianz今天宣布,該公司與Amazon Web Services (AWS)簽訂了...

關(guān)鍵字: AWS AN BSP 數(shù)字化

倫敦2024年8月29日 /美通社/ -- 英國汽車技術(shù)公司SODA.Auto推出其旗艦產(chǎn)品SODA V,這是全球首款涵蓋汽車工程師從創(chuàng)意到認證的所有需求的工具,可用于創(chuàng)建軟件定義汽車。 SODA V工具的開發(fā)耗時1.5...

關(guān)鍵字: 汽車 人工智能 智能驅(qū)動 BSP

北京2024年8月28日 /美通社/ -- 越來越多用戶希望企業(yè)業(yè)務(wù)能7×24不間斷運行,同時企業(yè)卻面臨越來越多業(yè)務(wù)中斷的風(fēng)險,如企業(yè)系統(tǒng)復(fù)雜性的增加,頻繁的功能更新和發(fā)布等。如何確保業(yè)務(wù)連續(xù)性,提升韌性,成...

關(guān)鍵字: 亞馬遜 解密 控制平面 BSP

8月30日消息,據(jù)媒體報道,騰訊和網(wǎng)易近期正在縮減他們對日本游戲市場的投資。

關(guān)鍵字: 騰訊 編碼器 CPU

8月28日消息,今天上午,2024中國國際大數(shù)據(jù)產(chǎn)業(yè)博覽會開幕式在貴陽舉行,華為董事、質(zhì)量流程IT總裁陶景文發(fā)表了演講。

關(guān)鍵字: 華為 12nm EDA 半導(dǎo)體

8月28日消息,在2024中國國際大數(shù)據(jù)產(chǎn)業(yè)博覽會上,華為常務(wù)董事、華為云CEO張平安發(fā)表演講稱,數(shù)字世界的話語權(quán)最終是由生態(tài)的繁榮決定的。

關(guān)鍵字: 華為 12nm 手機 衛(wèi)星通信

要點: 有效應(yīng)對環(huán)境變化,經(jīng)營業(yè)績穩(wěn)中有升 落實提質(zhì)增效舉措,毛利潤率延續(xù)升勢 戰(zhàn)略布局成效顯著,戰(zhàn)新業(yè)務(wù)引領(lǐng)增長 以科技創(chuàng)新為引領(lǐng),提升企業(yè)核心競爭力 堅持高質(zhì)量發(fā)展策略,塑強核心競爭優(yōu)勢...

關(guān)鍵字: 通信 BSP 電信運營商 數(shù)字經(jīng)濟

北京2024年8月27日 /美通社/ -- 8月21日,由中央廣播電視總臺與中國電影電視技術(shù)學(xué)會聯(lián)合牽頭組建的NVI技術(shù)創(chuàng)新聯(lián)盟在BIRTV2024超高清全產(chǎn)業(yè)鏈發(fā)展研討會上宣布正式成立。 活動現(xiàn)場 NVI技術(shù)創(chuàng)新聯(lián)...

關(guān)鍵字: VI 傳輸協(xié)議 音頻 BSP

北京2024年8月27日 /美通社/ -- 在8月23日舉辦的2024年長三角生態(tài)綠色一體化發(fā)展示范區(qū)聯(lián)合招商會上,軟通動力信息技術(shù)(集團)股份有限公司(以下簡稱"軟通動力")與長三角投資(上海)有限...

關(guān)鍵字: BSP 信息技術(shù)
關(guān)閉
關(guān)閉