美團149道面試題,全會拿40Koffer沒問題(Java程序員學習方向)

1、數據結構與算法基礎

· 說一下幾種常見的排序算法和分別的複雜度。
· 用Java寫一個冒泡排序算法
· 描述一下鏈式存儲結構。
· 如何遍歷一棵二叉樹?
· 倒排一個LinkedList。
· 用Java寫一個遞歸遍歷目錄下面的全部文件。java

2、Java基礎

· 接口與抽象類的區別?
· Java中的異常有哪幾類?分別怎麼使用?
· 經常使用的集合類有哪些?好比List如何排序?
· ArrayList和LinkedList內部的實現大體是怎樣的?他們之間的區別和優缺點?
· 內存溢出是怎麼回事?請舉一個例子?
· ==和equals的區別?
· hashCode方法的做用?
· NIO是什麼?適用於何種場景?
· HashMap實現原理,如何保證HashMap的線程安全?
· JVM內存結構,爲何須要GC?
· NIO模型,select/epoll的區別,多路複用的原理
· Java中一個字符佔多少個字節,擴展再問int, long, double佔多少字節
· 建立一個類的實例都有哪些辦法?
· final/finally/finalize的區別?
· Session/Cookie的區別?
· String/StringBuffer/StringBuilder的區別,擴展再問他們的實現?
· Servlet的生命週期?
· 如何用Java分配一段連續的1G的內存空間?須要注意些什麼?
· Java有本身的內存回收機制,但爲何還存在內存泄露的問題呢?
· 什麼是java序列化,如何實現java序列化?(寫一個實例)?
· String s = new String("abc");建立了幾個 String Object?mysql

3、JVM

· JVM堆的基本結構。
· JVM的垃圾算法有哪幾種?CMS垃圾回收的基本流程?
· JVM有哪些經常使用啓動參數能夠調整,描述幾個?
· 如何查看JVM的內存使用狀況?
· Java程序是否會內存溢出,內存泄露狀況發生?舉幾個例子。
· 你經常使用的JVM配置和調優參數都有哪些?分別什麼做用?
· JVM的內存結構?
· 經常使用的GC策略,何時會觸發YGC,何時觸發FGC?ios

4、多線程/併發

· 如何建立線程?如何保證線程安全?
· 如何實現一個線程安全的數據結構
· 如何避免死鎖
· Volatile關鍵字的做用?
· HashMap在多線程環境下使用須要注意什麼?爲何?
· Java程序中啓動一個線程是用run仍是start?
· 什麼是守護線程?有什麼用?
· 什麼是死鎖?如何避免
· 線程和進程的差異是什麼?
· Java裏面的Threadlocal是怎樣實現的?
· ConcurrentHashMap的實現原理是?
· sleep和wait區別
· notify和notifyAll區別
· volatile關鍵字的做
· ThreadLocal的做用與實現
· 兩個線程如何串行執行
· 上下文切換是什麼含義
· 能夠運行時kill掉一個線程嗎?
· 什麼是條件鎖、讀寫鎖、自旋鎖、可重入鎖?
· 線程池ThreadPoolExecutor的實現原理?程序員

5、Linux使用與問題分析排查

· 使用兩種命令建立一個文件?
· 硬連接和軟連接的區別?
· Linux經常使用命令有哪些?
· 怎麼看一個Java線程的資源耗用?
· Load太高的可能性有哪些?
· /etc/hosts文件什麼作用?
· 如何快速的將一個文本中全部「abc」替換爲「xyz」?
· 如何在log文件中搜索找出error的日誌?
· 發現磁盤空間不夠,如何快速找出佔用空間最大的文件?
· Java服務端問題排查(OOM,CPU高,Load高,類衝突)
· Java經常使用問題排查工具及用法(top, iostat, vmstat, sar, tcpdump, jvisualvm, jmap, jconsole)
· Thread dump文件如何分析(Runnable,鎖,代碼棧,操做系統線程ID關聯)
· 如何查看Java應用的線程信息?web

6、框架使用

· 描述一下Hibernate的三個狀態?
· Spring中Bean的生命週期。
· SpringMVC或Struts處理請求的流程。
· Spring AOP解決了什麼問題?怎麼實現的?
· Spring事務的傳播屬性是怎麼回事?它會影響什麼?
· Spring中BeanFactory和FactoryBean有什麼區別?
· Spring框架中IOC的原理是什麼?
· spring的依賴注入有哪幾種方式
· struts工做流程
· 用Spring如何實現一個切面?
· Spring 如何實現數據庫事務?
· Hibernate對一二級緩存的使用,Lazy-Load的理解;
· mybatis如何實現批量提交?面試

7、數據庫相關

· MySQL InnoDB、Mysaim的特色?
· 樂觀鎖和悲觀鎖的區別?
· 數據庫隔離級別是什麼?有什麼做用?
· MySQL主備同步的基本原理。
· select * from table t where size > 10 group by size order by size的sql語句執行順序?
· 如何優化數據庫性能(索引、分庫分表、批量操做、分頁算法、升級硬盤SSD、業務優化、主從部署)
· SQL什麼狀況下不會使用索引(不包含,不等於,函數)
· 通常在什麼字段上建索引(過濾數據最多的字段)
· 如何從一張表中查出name字段不包含「XYZ」的全部行?
· MySQL,B+索引實現,行鎖實現,SQL優化
· Redis,RDB和AOF,如何作高可用、集羣
· 如何解決高併發減庫存問題
· mysql存儲引擎中索引的實現機制;
· 數據庫事務的幾種粒度;
· 行鎖,表鎖;樂觀鎖,悲觀鎖redis

8、網絡協議和網絡編程

· TCP創建鏈接的過程。
· TCP斷開鏈接的過程。
· 瀏覽器發生302跳轉背後的邏輯?
· HTTP協議的交互流程。HTTP和HTTPS的差別,SSL的交互流程?
· Rest和Http什麼關係?你們都說Rest很輕量,你對Rest風格如何理解?
· TCP的滑動窗口協議有什麼用?講講原理。
· HTTP協議都有哪些方法?
· 交換機和路由器的區別?
· Socket交互的基本流程?
· 協議(報文結構,斷點續傳,多線程下載,什麼是長鏈接)
· tcp協議(建連過程,慢啓動,滑動窗口,七層模型)
· webservice協議(wsdl/soap格式,與rest協議的區別)
· NIO的好處,Netty線程模型,什麼是零拷貝算法

9、Redis等緩存系統/中間件/NoSQL/一致性Hash等

· 列舉一個經常使用的Redis客戶端的併發模型。
· HBase如何實現模糊查詢?
· 列舉一個經常使用的消息中間件,若是消息要保序如何實現?
· 如何實現一個Hashtable?你的設計如何考慮Hash衝突?如何優化?
· 分佈式緩存,一致性hash
· LRU算法,slab分配,如何減小內存碎片
· 如何解決緩存單機熱點問題
· 什麼是布隆過濾器,其實現原理是? False positive指的是?
· memcache與redis的區別
· zookeeper有什麼功能,選舉算法如何進行
· map/reduce過程,如何用map/reduce實現兩個數據源的聯合統計spring

10、設計模式與重構

· 你能舉例幾個常見的設計模式
· 你在設計一個工廠的包的時候會遵循哪些原則?
· 你能列舉一個使用了Visitor/Decorator模式的開源項目/庫嗎?
· 你在編碼時最經常使用的設計模式有哪些?在什麼場景下用?
· 如何實現一個單例?
· 代理模式(動態代理)
· 單例模式(懶漢模式,惡漢模式,併發初始化如何解決,volatile與lock的使用)
· JDK源碼裏面都有些什麼讓你印象深入的設計模式使用,舉例看看?sql

十一:微服務

一、什麼是微服務?

二、微服務之間是如何獨立通信的

三、springCloud和dubbo 有哪些區別?

四、springboot和springcloud,請你談談對他們的理解?

五、什麼是微服務熔斷?什麼是服務降級?

六、微服務的優缺點分別是什麼?說下你在項目開發中碰到的坑

七、你所知道的微服務技術棧有哪些?請列舉一二

八、eureka和zookeeper均可以提供服務的註冊和發現的功能,請說說兩個的區別?

相信你可能經歷過這些:

已經工做兩三年了,每一個項目都會加班加點盡心盡力去完成,薪資增加幅度卻不如人意。

據說年後離職的老同事,跳槽剛拿下高薪offer,年薪直奔50萬了。

因爲如今的公司接觸不到新技術,對本身的市場競爭力無比焦慮,將來職業道路怎麼走?

這個凜冽寒冬,你終於明白,如今的工做機會不多,薪資很難有較大漲幅,Java工程師的年薪是技能決定的,是時候去提升技能,提早規劃將來職業發展路徑了。

做爲Java工程師的你,平時工做已經很忙了,到底該如何進階,才能快速成長呢?

分享一些過來人的經驗,供你們參考。

一朝成爲Java工程師,就註定終身學習。
在Mike的13年的Java工程師生涯中,這一點深有體會,而讓我堅持學習的動力,主要源於如下三個方面:

一、 不斷增值本身,擁有更多選擇權

若是將技術比作一棵樹,每學會一門語言,就點亮樹上一個果實,你會得越多,技術樹的果實就越多,價值就越大。當技術樹的果實積累到必定程度,你就能縱向往高階技術方向晉級,職業發展之路更上一層樓。

二、 互聯網沒有溫馨圈,止步不前即是退步

計算機技術更新迭代快、新技術層出不窮,若是想要成爲一個優秀的Java工程師,就要作好隨時學習的準備,並鍥而不捨,這樣才能跟上互聯網突飛猛進的發展節奏。

三、 學習是面對競爭、度過中年危機的最好方法

Java工程師是高薪職業,近年來互聯網的高速發展下,更是一度成爲搶手的熱門職業,以致於投身到這個職業的人愈來愈多,千軍萬馬過獨木橋,想要不掉隊,惟有努力學習,成爲互聯網公司高薪爭搶的中高端Java工程師,才能不懼寒冬。

目前互聯網寒冬讓不少互聯網人清醒了,衆多大企裁人、招聘需求收縮,主要仍是針對基礎崗、溫水煮青蛙給煮死的那波人,中高端Java工程師在市場上依然緊缺。

互聯網公司主流技術選型
進階高級Java、架構師必學6大主要技能,包括:數據結構和算法、Java高級特性、源碼分析、數據庫、Java框架與必備工具、系統架構設計等,但願能真正幫助到想要從程序員進階爲高級Java、架構師之路的朋友。

一、併發編程

經過深刻了解最底層的運做原理,增強邏輯思惟,才能編寫出高效、安全的多線程併發程序。

包括:集合框架(源碼)、工具類、框架Spring、SpringMVC、Mybatis、Shiro、Netty、服務器(tomcat、Nginx)、網絡編程、序列化、JVM等。

![clipboard.
clipboard.png
v7WD)

![圖片上傳中...]

二、設計模式

設計模式是可複用面向對象軟件的基礎,學習設計模試是每一位Java工程師進階的必經之路,靈活地使用設計模式,可讓代碼變得簡潔、易懂、複用性更高。

常見經常使用
clipboard.png
理模式等。

![圖片上傳中...]
三、研發相關的框架工具

對Java程序員來講,下圖這些框架與工具常常會用到。工欲善其事必先利其器,熟練掌握並應用這些工具,可以幫助咱們更高效、質量的開展工做,譬如,debug、高效去重、代碼review等等。

clipboard.png

三、分佈式架構

隨着業務體量及重要性的增大,單體架構模式沒法對應大型應用場景,系統也決不容許存在單點故障致使總體不可用,因此只有垂直或水平拆分業務系統,造成一個分佈式的架構來消除單點故障,從而提升整個系統的可用性。

包括:分佈式Session、分佈式緩存、數據庫、一致性、負載均衡、消息隊列(Rabbi
clipboard.png
fka)等

![圖片上傳中...]
四、微服務

因時因地制宜,選擇使用微服務架構的收益將遠遠大於成本。

規模較少的企業能夠考慮適當引入合適的微服務架構,改造已有系統或新建微服務應用,逐步積累微服務架構經驗,不要全盤實施微服務架構,綜合考量成本與效率、實用性。

Mike在往期發佈的架構系列《BAT架構技術專題合集》中,有針對微服務的系列篇,文末有查看地址。

![clipbo
clipboard.png
/bVbv7Xb)
五、JVM性能優化

![圖片上傳中..
clipboard.png
設施**

![圖片上傳中...]
最後,Mike想說,職場也好,人生也罷,每一個階段都有必定的阻礙與瓶頸,這是咱們都要經歷的。

若是你可以認清本身以及本身所處的階段,有針對性的去思考、充電,堅持作正確的事,付出比別人更多的努力,你就會比別人更加優秀,擁有更多的機會,這就是咱們常說的馬太效應:越努力,越幸運。

BAT面試真題+架構技術資料,提高軟硬實力,收穫高薪好offer
說了這麼多,到底該如何學習呢,有沒有資料或視頻呀?

大廠Java面試題庫、BAT架構技術資料庫(關注小編,加Java高級開發:536976563進羣便可獲取往期BAT資料以及視頻。)

資料內容涵蓋BAT架構技術與面試真題,減小你處處搜索資料的時間,成體系的實戰技術知識,讓你面試、進階都更加容易。

clipboard.png

clipboard.png

相關文章
相關標籤/搜索