成為頂尖架構師必須要面對的面試題


一、數據結構與算法基礎 

  · 說一下幾種常見的排序算法和分別的復雜度。 

  · 用Java寫一個冒泡排序算法 

  · 描述一下鏈式存儲結構。 

  · 如何遍歷一棵二叉樹? 

  · 倒排一個LinkedList。 

  · 用Java寫一個遞歸遍歷目錄下面的所有文件。 

  二、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? 

  三、JVM 

  · JVM堆的基本結構。 

  · JVM的垃圾算法有哪幾種?CMS垃圾回收的基本流程? 

  · JVM有哪些常用啟動參數可以調整,描述幾個? 

  · 如何查看JVM的內存使用情況? 

  · Java程序是否會內存溢出,內存泄露情況發生?舉幾個例子。 

  · 你常用的JVM配置和調優參數都有哪些?分別什么作用? 

  · JVM的內存結構? 

  · 常用的GC策略,什么時候會觸發YGC,什么時候觸發FGC? 

  四、多線程/並發 

  · 如何創建線程?如何保證線程安全? 

  · 如何實現一個線程安全的數據結構 

  · 如何避免死鎖 

  · Volatile關鍵字的作用? 

  · HashMap在多線程環境下使用需要注意什么?為什么? 

  · Java程序中啟動一個線程是用run還是start? 

  · 什么是守護線程?有什么用? 

  · 什么是死鎖?如何避免 

  · 線程和進程的差別是什么? 

  · Java里面的Threadlocal是怎樣實現的? 

  · ConcurrentHashMap的實現原理是? 

  · sleep和wait區別 

  · notify和notifyAll區別 

  · volatile關鍵字的作 

  · ThreadLocal的作用與實現 

  · 兩個線程如何串行執行 

  · 上下文切換是什么含義 

  · 可以運行時kill掉一個線程嗎? 

  · 什么是條件鎖、讀寫鎖、自旋鎖、可重入鎖? 

  · 線程池ThreadPoolExecutor的實現原理? 

  五、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應用的線程信息? 

  六、框架使用 

  · 描述一下Hibernate的三個狀態? 

  · Spring中Bean的生命周期。 

  · SpringMVC或Struts處理請求的流程。 

  · Spring AOP解決了什么問題?怎么實現的? 

  · Spring事務的傳播屬性是怎么回事?它會影響什么? 

  · Spring中BeanFactory和FactoryBean有什么區別? 

  · Spring框架中IOC的原理是什么? 

  · spring的依賴注入有哪幾種方式 

  · struts工作流程 

  · 用Spring如何實現一個切面? 

  · Spring 如何實現數據庫事務? 

  · Hibernate對一二級緩存的使用,Lazy-Load的理解; 

  · mybatis如何實現批量提交? 

  七、數據庫相關 

  · 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存儲引擎中索引的實現機制; 

  · 數據庫事務的幾種粒度; 

  · 行鎖,表鎖;樂觀鎖,悲觀鎖 

  八、網絡協議和網絡編程 

  · TCP建立連接的過程。 

  · TCP斷開連接的過程。 

  · 瀏覽器發生302跳轉背后的邏輯? 

  · HTTP協議的交互流程。HTTP和HTTPS的差異,SSL的交互流程? 

  · Rest和Http什么關系?大家都說Rest很輕量,你對Rest風格如何理解? 

  · TCP的滑動窗口協議有什么用?講講原理。 

  · HTTP協議都有哪些方法? 

  · 交換機和路由器的區別? 

  · Socket交互的基本流程? 

  · 協議(報文結構,斷點續傳,多線程下載,什么是長連接) 

  · tcp協議(建連過程,慢啟動,滑動窗口,七層模型) 

  · webservice協議(wsdl/soap格式,與rest協議的區別) 

  · NIO的好處,Netty線程模型,什么是零拷貝 

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

  · 列舉一個常用的Redis客戶端的並發模型。 

  · HBase如何實現模糊查詢? 

  · 列舉一個常用的消息中間件,如果消息要保序如何實現? 

  · 如何實現一個Hashtable?你的設計如何考慮Hash沖突?如何優化? 

  · 分布式緩存,一致性hash 

  · LRU算法,slab分配,如何減少內存碎片 

  · 如何解決緩存單機熱點問題 

  · 什么是布隆過濾器,其實現原理是? False positive指的是? 

  · memcache與redis的區別 

  · zookeeper有什么功能,選舉算法如何進行 

  · map/reduce過程,如何用map/reduce實現兩個數據源的聯合統計 

  十、設計模式與重構 

  · 你能舉例幾個常見的設計模式 

  · 你在設計一個工廠的包的時候會遵循哪些原則? 

  · 你能列舉一個使用了Visitor/Decorator模式的開源項目/庫嗎? 

  · 你在編碼時最常用的設計模式有哪些?在什么場景下用? 

  · 如何實現一個單例? 

  · 代理模式(動態代理) 

  · 單例模式(懶漢模式,惡漢模式,並發初始化如何解決,volatile與lock的使用) 

  · JDK源碼里面都有些什么讓你印象深刻的設計模式使用,舉例看看? 

PS:如果你想成為一名優秀的架構師,或者在工作中遇到瓶頸,想跳槽加薪,面試不過, 
碰到難題等等一系列問題,可以加我的架構師群:554355695 
這里有最專業的團隊為你排憂解難,有最新的學習資源免費為你共享。 
如果你想學習Java工程化、高性能及分布式、高性能、深入淺出。 
性能調優、Spring,MyBatis,Netty源碼分析和大數據等知識點可以加我的Java架構進階群:554355695 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM