原文:http://www.cnblogs.com/RunForLove/p/5691339.htmlhtml
1、Java基礎node
1. 實例方法和靜態方法有什麼不同?mysql
2. Java中的異常有哪幾類?分別怎麼使用?ios
3. 經常使用的集合類有哪些?好比List如何排序?web
4. ArrayList和LinkedList內部的實現大體是怎樣的?他們之間的區別和各自適應的場景是什麼?redis
5. 內存溢出是怎麼回事?算法
6. ClassLoader有什麼用?spring
7. ==和equals的區別?sql
8. hashCode方法的做用?shell
9. Object類中有哪些方法?列舉3個以上。
10. NIO是什麼?適用於何種場景?
12. HashMap數據結構、擴展策略,Hash衝突攻擊如何防範,如何實現線程安全的HashMap?
13. JVM內存結構,GC算法,CMS、G1的原理
14. NIO模型,select/epoll的區別,多路複用的原理
16. Java中一個字符佔多少個字節,擴展再問int, long, double佔多少字節
17. 建立一個類的實例都有哪些辦法?
18. final/finally/finalize的區別?
19. LinkingBlockingQueue與ArrayBlockingQueue的區別,他們的適用場景?
20. Session/Cookie的區別?
21. String/StringBuffer/StringBuilder的區別,擴展再問他們的實現?
22. Servlet的生命週期?
23. 如何用Java分配一段連續的1G的內存空間?須要注意些什麼?
24. Java有本身的內存回收機制,但爲何還存在內存泄露的問題呢?
25. Java裏面用對象做爲Key須要注意些什麼? 如何實現hashcode?
2、JVM
1. JVM堆的基本結構。
2. JVM的垃圾算法有哪幾種?CMS收集算法的流程?
3. JVM有哪些經常使用啓動參數能夠調整?
4. 如何查看JVM的內存使用狀況?
5. Java程序是否會內存溢出?
6. 你經常使用的JVM配置和調優參數都有哪些?分別什麼做用?
7. Java內存分代模型,GC算法,JVM常見的啓動參數;
8. CMS算法的過程,CMS回收過程當中JVM是否須要暫停(這塊回答較好,也能夠只是看畢玄的Java分佈式開發或網上文章的學習, 能夠結合JVM啓動參數常見配置,jstat等命令,看下動手能力,意願;以及實際線上問題排查)
9. 什麼狀況下會出現OOM(堆內存,永久區,堆外區,方法棧)
10. Java內存結構(堆結構,新生代[S0/S1/Elden],年老代,持久代)
11. 經常使用的GC策略,何時會觸發YGC,何時觸發FGC
3、數據結構與算法基礎
1. 說一下幾種常見的排序算法和分別的複雜度。
2. 什麼是跳錶?
3. 如何確認一個鏈表有環?進一步,確認環的位置。
4. 如何遍歷一棵二叉樹?
5. 倒排一個LinkedList。
6. HashSet的實現方式
4、多線程/併發
1. Java中常見的鎖,互斥鎖,讀寫鎖,信號量
2. 原子Atomic類,如何保證原子性,CAS硬件指令
3. volatile,可見性問題的緣由,硬件架構,L3 Cache,QPI,樂觀鎖
4. 如何實現一個線程安全的數據結構
5. 如何避免死鎖
6. 如何解決ABA問題
7. Synchronized關鍵字的做用?
8. Volatile關鍵字的做用?
9. Java內存模型是怎樣的?
10. HashMap在多線程環境下使用須要注意什麼?爲何?
11. Java程序中啓動一個線程是用run()仍是start()?
12. 什麼是守護線程?有什麼用?
13. 什麼是死鎖?如何避免
14. 線程和進程的差異是什麼?
15. Java裏面的Threadlocal是怎樣實現的?
16. ConcurrentHashMap的實現原理是?
17. sleep和wait區別
18. notify和notifyAll區別
19. volatile關鍵字的做用
20. ThreadLocal的做用與實現
21. 兩個線程如何串行執行
22. 上下文切換是什麼含義
23. 能夠運行時kill掉一個線程嗎?
24. 什麼是條件鎖、讀寫鎖、自旋鎖、可重入鎖?
25. 什麼是協程(用戶態線程,減小數據拷貝,下降CPU開銷,無callback函數)?
26. 線程池ThreadPoolExecutor的實現原理?
27. J.U.C下的常見類的使用。lock, synchronized, ThreadPool的深刻考察; BlockingQueue的使用。(take,poll的區別,put,offer的區別);原子類的實現。
28. 各類常見鎖使用若是上面這些掌握很好,還能夠看看更深一點的 False Sharing,Cache Line,可見性與原子性等;
5、Linux使用與問題分析排查
1. 硬連接和軟連接的區別?
2. inode是什麼?
3. Linux經常使用命令有哪些?
4. 怎麼看一個Java線程的資源耗用?
5. Load太高的可能性有哪些?
6. /etc/hosts文件什麼作用?
7. /etc/resolv.conf文件什麼做用?
8. 如何快速的將一個文本中全部「abc」替換爲「xyz」?
9. 你經常使用的Linux下用來進行網絡和磁盤IO分析的工具備哪些?
10. 你經常使用的Linux下用來進行內存和CPU分析的工具備哪些?
11. 發現磁盤空間不夠,如何快速找出佔用空間最大的文件?
12. Java服務端問題排查(OOM,CPU高,Load高,類衝突)
13. Java經常使用問題排查工具及用法(top, iostat, vmstat, sar, tcpdump, jvisualvm, jmap, jconsole)
14. Thread dump文件如何分析(Runnable,鎖,代碼棧,操做系統線程ID關聯)
15. grep,awk,sed; 是否本身寫過shell腳本;
16. 常見的cpu load太高,us太高,通常是什麼問題。引伸出是否用過top,jstat,jstack等。
17. 常見的內存問題通常有哪些。 引伸出是否用過free,top, jmap等。
6、框架使用
1. Spring中Bean的生命週期。
2. SpringMVC或Struts處理請求的流程。
3. Spring AOP解決了什麼問題?怎麼實現的?aop與cglib,與asm的關係。
4. Spring事務的傳播屬性是怎麼回事?它會影響什麼?
5. Spring中BeanFactory和FactoryBean有什麼區別?
6. Spring框架中IOC的原理是什麼?
7. spring的依賴注入有哪幾種方式
8. struts工做流程
9. 用Spring如何實現一個切面?
10. Spring 如何實現數據庫事務?
11. Hibernate和Ibatis這類ORM框架的區別?什麼是ORM,解決的痛點是什麼?
12. spriong ioc的生命週期,(init-method,intilizingbean接口方法afterPropertiesSet的前後順序)等。
13. Hibernate對一二級緩存的使用,Lazy-Load的理解;
14. Spring IoC AOP本身用代碼如何實現
15. RPC的負載均衡、服務發現怎麼作的
16. 幾種推送模型的區別,long polling,websocket
7、數據庫相關
1. MySQL InnoDB的特色?
2. 樂觀鎖和悲觀鎖的區別?
3. 數據庫隔離級別是什麼?有什麼做用?
4. MySQL主備同步的基本原理。
5. 如何從一張表中查出name字段包含「XYZ」的全部行?
6. 索引數據結構(字典+BitTree)
7. 如何優化數據庫性能(索引、分庫分表、批量操做、分頁算法、升級硬盤SSD、業務優化、主從部署)
8. SQL什麼狀況下不會使用索引(不包含,不等於,函數)
9. 通常在什麼字段上建索引(過濾數據最多的字段)
10. 如何從一張表中查出name字段不包含「XYZ」的全部行?
11. MySQL,B+索引實現,行鎖實現,SQL優化
12. Redis,RDB和AOF,如何作高可用、集羣
13. 如何解決高併發減庫存問題
14. mysql存儲引擎中索引的實現機制;
15. 數據庫事務的幾種粒度;
16. 行鎖,表鎖;樂觀鎖,悲觀鎖
8、網絡協議和網絡編程
1. TCP創建鏈接的過程。
2. TCP斷開鏈接的過程。
3. 瀏覽器發生302跳轉背後的邏輯?
4. HTTP協議的交互流程。HTTP和HTTPS的差別,SSL的交互流程?
5. Rest和Http什麼關係? 你們都說Rest很輕量,你對Rest風格如何理解?
6. TCP的滑動窗口協議有什麼用?講講原理。
7. HTTP協議都有哪些方法?
8. 交換機和路由器的區別?
9. 什麼是VLAN,有什麼做用?
10. 什麼是VXLAN,有什麼做用?
11. http協議(報文結構,斷點續傳,多線程下載,什麼是長鏈接)
12. tcp協議(建連過程,慢啓動,滑動窗口,七層模型)
13. webservice協議(wsdl/soap格式,與rest協議的區別)
14. spdy/http2.0協議是否有了解
15. NIO的好處,Netty線程模型,什麼是零拷貝
9、Redis等緩存系統/中間件/NoSQL/一致性Hash等
1. 列舉一個經常使用的Redis客戶端的併發模型。
2. HBase如何實現模糊查詢?
3. 列舉一個經常使用的消息中間件,若是消息要保序如何實現?
4. 如何實現一個Hashtable?你的設計如何考慮Hash衝突?如何優化?
5. 分佈式緩存,一致性hash
6. LRU算法,slab分配,如何減小內存碎片
7. 如何解決緩存單機熱點問題
8. 什麼是布隆過濾器,其實現原理是? False positive指的是?
9. memcache與redis的區別
10. zookeeper有什麼功能,選舉算法如何進行
11. map/reduce過程,如何用map/reduce實現兩個數據源的聯合統計
10、設計模式與重構
1. 你在設計一個工廠的包的時候會遵循哪些原則?
2. 你能列舉一個使用了Visitor/Decorator模式的開源項目/庫嗎?
3. 你在編碼時最經常使用的設計模式有哪些?在什麼場景下用?
4. 如何實現一個單例?
5. 代理模式(動態代理)
6. 單例模式(懶漢模式,惡漢模式,併發初始化如何解決,volatile與lock的使用)
7. JDK源碼裏面都有些什麼讓你印象深入的設計模式使用,舉例看看?
8. Reactor模式
11、學習與進取心
1. 平時會關注哪些技術?
2. 會看那些技術博客和網站?
3. 技術上有沒有偶像?
4. 看過哪些技術書籍?
5. 你日常都看些什麼書?你去年和今年看的書中印象最深的基本技術書籍和非技術書籍是?
6. (若是不看書)你日常都上哪些技術論壇?最喜歡哪一個?爲何?
7. 項目或產品中用到了什麼新技術或框架
8. 最近研究過什麼業界流行的技術或框架
9. 對如今所作的項目或產品的缺陷是否瞭解,有何規劃
10. 是否有帶過項目,如何管理項目
11. 是否有帶過團隊,團隊管理最大的挑戰點是什麼
12、抗壓能力及抗壓意願
1. 剛纔你說的XXX實現跟那個開源的YYY很像,是否是抄來的?
2. 對加班怎麼看?
3. 平臺是否有加班,是主動仍是被動,是否很是抗拒
4. 是否有負責多件事情,多件事情如何並行處理
5. 你對你最近負責項目中最自豪的點是什麼?
十3、穩定性考察
1. 瞭解家庭婚姻情況, 瞭解購房及居住地,籍貫狀況,瞭解目前薪資,評估穩定性
2. 若是讓你接手一個歷史悠久的模塊,你會怎麼作?
3. 看簡歷跳槽狀況,針對性發問,如跳槽頻繁的話問清楚爲何
十4、開放性問題
1. 一個大文件4G,裏面一行行的數字,這時內存只有256M,若是作排序?
2. 若是你部署的應用所在機器硬盤壞了,會發生什麼?你的程序要如何處理這種異常?(分佈式系統中故障是一種常態,設計要避免單點故障,能容錯,保證系統高可用)
3. 實現一個消息隊列系統
4. 如何設計一個高可用的架構
5. 屢次Hash來解決URL重複訪問問題。
6. 全局惟一ID問題。
7. 秒殺如何設計。
8. 如何進行性能優化。
9. 發現CPU 100%,如何排查?
10. 實現一個分佈式打點系統。
11. taobao.com和tmall.com的互相登陸的問題。
12. 如何快速對一個2億數據的List進行排序?