程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 編程語言 >> JAVA編程 >> JAVA綜合教程 >> 商家事業部面試(Ali),商家事業部面試ali

商家事業部面試(Ali),商家事業部面試ali

編輯:JAVA綜合教程

商家事業部面試(Ali),商家事業部面試ali


一、Java基礎

1. 實例方法和靜態方法有什麼不一樣?

2. Java中的異常有哪幾類?分別怎麼使用?

3. 常用的集合類有哪些?比如List如何排序?

4. ArrayList和LinkedList內部的實現大致是怎樣的?他們之間的區別和各自適應的場景是什麼?

5. 內存溢出是怎麼回事?

6. ClassLoader有什麼用?

7. ==和equals的區別?

8. hashCode方法的作用?

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? 

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

三、數據結構與算法基礎 

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

2. 什麼是跳表?

3. 如何確認一個鏈表有環?進一步,確認環的位置。

4. 如何遍歷一棵二叉樹?

5. 倒排一個LinkedList。  

6. HashSet的實現方式

四、多線程/並發

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,可見性與原子性等; 

五、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等。

六、框架使用

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 

七、數據庫相關

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. 行鎖,表鎖;樂觀鎖,悲觀鎖 

八、網絡協議和網絡編程

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線程模型,什麼是零拷貝 

九、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實現兩個數據源的聯合統計 

十、設計模式與重構

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

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

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

4. 如何實現一個單例?

5. 代理模式(動態代理)

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

7. JDK源碼裡面都有些什麼讓你印象深刻的設計模式使用,舉例看看?

8. Reactor模式 

十一、學習與進取心

1. 平時會關注哪些技術?

2. 會看那些技術博客和網站?

3. 技術上有沒有偶像?

4. 看過哪些技術書籍?

5. 你平常都看些什麼書?你去年和今年看的書中印象最深的基本技術書籍和非技術書籍是?

6. (如果不看書)你平常都上哪些技術論壇?最喜歡哪個?為什麼?

7. 項目或產品中用到了什麼新技術或框架

8. 最近研究過什麼業界流行的技術或框架

9. 對現在所做的項目或產品的缺陷是否了解,有何規劃

10. 是否有帶過項目,如何管理項目

11. 是否有帶過團隊,團隊管理最大的挑戰點是什麼 

十二、抗壓能力及抗壓意願

1. 剛才你說的XXX實現跟那個開源的YYY很像,是不是抄來的?

2. 對加班怎麼看?

3. 平台是否有加班,是主動還是被動,是否非常抗拒

4. 是否有負責多件事情,多件事情如何並行處理

5. 你對你最近負責項目中最自豪的點是什麼? 

十三、穩定性考察

1. 了解家庭婚姻狀況, 了解購房及居住地,籍貫情況,了解目前薪資,評估穩定性

2. 如果讓你接手一個歷史悠久的模塊,你會怎麼做?

3. 看簡歷跳槽情況,針對性發問,如跳槽頻繁的話問清楚為什麼 

十四、開放性問題

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進行排序? 

  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved