2019年最全BAT一線大廠面試真題總結(jié),“火燒赤壁”只差一陣風(fēng)!

這些題目是網(wǎng)友去百度、小米、樂(lè)視、美團(tuán)、58、獵豹、360、新浪、搜狐等一線互聯(lián)網(wǎng)公司面試被問(wèn)到的題目。熟悉本文中列出的知識(shí)點(diǎn)會(huì)大大增加通過(guò)前兩輪技術(shù)面試的幾率。

網(wǎng)上的都是按照公司劃分的,想找具體某一方面的知識(shí)點(diǎn)有點(diǎn)不好找,我這里就根據(jù)知識(shí)點(diǎn)分門(mén)別類(lèi)的整理了一下,想看哪一塊可以快速找到,希望可以幫助大家,祝大家求職順利。

因文章篇幅問(wèn)題,我這里沒(méi)有進(jìn)行題目解析,不過(guò)我已整理好了PDF文檔,有需要的各位程序員們可以進(jìn)我的學(xué)習(xí)交流群:909666042 免費(fèi)獲取!

主要分為以下幾部分:

(1)java面試題
(2)Android面試題
(3)混合開(kāi)發(fā)面試題
(4)高端技術(shù)面試題
(5)非技術(shù)性問(wèn)題&HR問(wèn)題匯總

一、Java面試題

熟練掌握java是很關(guān)鍵的,大公司不僅僅要求你會(huì)使用幾個(gè)api,更多的是要你熟悉源碼實(shí)現(xiàn)原理,甚至要你知道有哪些不足,怎么改進(jìn),還有一些java有關(guān)的一些算法,設(shè)計(jì)模式等等。

(一) Java基礎(chǔ)面試知識(shí)點(diǎn)

  1. java中==和equals和hashCode的區(qū)別
  2. int、char、long各占多少字節(jié)數(shù)
  3. int與integer的區(qū)別
  4. 談?wù)剬?duì)java多態(tài)的理解
  5. String、StringBuffer、StringBuilder區(qū)別
  6. 什么是內(nèi)部類(lèi)??jī)?nèi)部類(lèi)的作用
  7. 抽象類(lèi)和接口區(qū)別
  8. 抽象類(lèi)的意義
  9. 抽象類(lèi)與接口的應(yīng)用場(chǎng)景
  10. 抽象類(lèi)是否可以沒(méi)有方法和屬性?
  11. 接口的意義
  12. 泛型中extends和super的區(qū)別
  13. 父類(lèi)的靜態(tài)方法能否被子類(lèi)重寫(xiě)
  14. 進(jìn)程和線程的區(qū)別
  15. final,finally,finalize的區(qū)別
  16. 序列化的方式
  17. Serializable 和Parcelable 的區(qū)別
  18. 靜態(tài)屬性和靜態(tài)方法是否可以被繼承?是否可以被重寫(xiě)?以及原因?
  19. 靜態(tài)內(nèi)部類(lèi)的設(shè)計(jì)意圖
  20. 成員內(nèi)部類(lèi)、靜態(tài)內(nèi)部類(lèi)、局部?jī)?nèi)部類(lèi)和匿名內(nèi)部類(lèi)的理解,以及項(xiàng)目中的應(yīng)用
  21. 談?wù)剬?duì)kotlin的理解
  22. 閉包和局部?jī)?nèi)部類(lèi)的區(qū)別
  23. string 轉(zhuǎn)換成 integer的方式及原理

(二)Java深入源碼級(jí)的面試題(有難度)

  1. 哪些情況下的對(duì)象會(huì)被垃圾回收機(jī)制處理掉?
  2. 講一下常見(jiàn)編碼方式?
  3. utf-8編碼中的中文占幾個(gè)字節(jié);int型幾個(gè)字節(jié)?
  4. 靜態(tài)代理和動(dòng)態(tài)代理的區(qū)別,什么場(chǎng)景使用?
  5. Java的異常體系
  6. 談?wù)勀銓?duì)解析與分派的認(rèn)識(shí)。
  7. 修改對(duì)象A的equals方法的簽名,那么使用HashMap存放這個(gè)對(duì)象實(shí)例的時(shí)候,會(huì)調(diào)用哪個(gè)equals方法?
  8. Java中實(shí)現(xiàn)多態(tài)的機(jī)制是什么?
  9. 如何將一個(gè)Java對(duì)象序列化到文件里?
  10. 說(shuō)說(shuō)你對(duì)Java反射的理解
  11. 說(shuō)說(shuō)你對(duì)Java注解的理解
  12. 說(shuō)說(shuō)你對(duì)依賴(lài)注入的理解
  13. 說(shuō)一下泛型原理,并舉例說(shuō)明
  14. Java中String的了解
  15. String為什么要設(shè)計(jì)成不可變的?
  16. Object類(lèi)的equal和hashCode方法重寫(xiě),為什么?

(三) 數(shù)據(jù)結(jié)構(gòu)

  1. 常用數(shù)據(jù)結(jié)構(gòu)簡(jiǎn)介
  2. 并發(fā)集合了解哪些?
  3. 列舉java的集合以及集合之間的繼承關(guān)系
  4. 集合類(lèi)以及集合框架
  5. 容器類(lèi)介紹以及之間的區(qū)別(容器類(lèi)估計(jì)很多人沒(méi)聽(tīng)這個(gè)詞,Java容器主要可以劃分為4個(gè)部分:List列表、Set集合、Map映射、工具類(lèi)(Iterator迭代器、Enumeration枚舉類(lèi)、Arrays和Collections)
  6. List,Set,Map的區(qū)別
  7. List和Map的實(shí)現(xiàn)方式以及存儲(chǔ)方式
  8. HashMap的實(shí)現(xiàn)原理
  9. HashMap數(shù)據(jù)結(jié)構(gòu)?
  10. HashMap源碼理解
  11. HashMap如何put數(shù)據(jù)(從HashMap源碼角度講解)?
  12. HashMap怎么手寫(xiě)實(shí)現(xiàn)?
  13. ConcurrentHashMap的實(shí)現(xiàn)原理
  14. ArrayMap和HashMap的對(duì)比
  15. HashTable實(shí)現(xiàn)原理
  16. TreeMap具體實(shí)現(xiàn)
  17. HashMap和HashTable的區(qū)別
  18. HashMap與HashSet的區(qū)別
  19. HashSet與HashMap怎么判斷集合元素重復(fù)?
  20. 集合Set實(shí)現(xiàn)Hash怎么防止碰撞
  21. ArrayList和LinkedList的區(qū)別,以及應(yīng)用場(chǎng)景
  22. 數(shù)組和鏈表的區(qū)別
  23. 二叉樹(shù)的深度優(yōu)先遍歷和廣度優(yōu)先遍歷的具體實(shí)現(xiàn)
  24. 堆的結(jié)構(gòu)
  25. 堆和樹(shù)的區(qū)別
  26. 堆和棧在內(nèi)存中的區(qū)別是什么(解答提示:可以從數(shù)據(jù)結(jié)構(gòu)方面以及實(shí)際實(shí)現(xiàn)方面兩個(gè)方面去回答)?
  27. 什么是深拷貝和淺拷貝
  28. 手寫(xiě)鏈表逆序代碼
  29. 講一下對(duì)樹(shù),B+樹(shù)的理解
  30. 講一下對(duì)圖的理解
  31. 判斷單鏈表成環(huán)與否?
  32. 鏈表翻轉(zhuǎn)(即:翻轉(zhuǎn)一個(gè)單項(xiàng)鏈表)
  33. 合并多個(gè)單有序鏈表(假設(shè)都是遞增的)

(四) 線程、多線程和線程池

  1. 開(kāi)啟線程的三種方式?
  2. 線程和進(jìn)程的區(qū)別?
  3. 為什么要有線程,而不是僅僅用進(jìn)程?
  4. run()和start()方法區(qū)別
  5. 如何控制某個(gè)方法允許并發(fā)訪問(wèn)線程的個(gè)數(shù)?
  6. 在Java中wait和seelp方法的不同;
  7. 談?wù)剋ait/notify關(guān)鍵字的理解
  8. 什么導(dǎo)致線程阻塞?
  9. 線程如何關(guān)閉?
  10. 講一下java中的同步的方法
  11. 數(shù)據(jù)一致性如何保證?
  12. 如何保證線程安全?
  13. 如何實(shí)現(xiàn)線程同步?
  14. 兩個(gè)進(jìn)程同時(shí)要求寫(xiě)或者讀,能不能實(shí)現(xiàn)?如何防止進(jìn)程的同步?
  15. 線程間操作List
  16. Java中對(duì)象的生命周期
  17. Synchronized用法
  18. synchronize的原理
  19. 談?wù)剬?duì)Synchronized關(guān)鍵字,類(lèi)鎖,方法鎖,重入鎖的理解
  20. static synchronized 方法的多線程訪問(wèn)和作用
  21. 同一個(gè)類(lèi)里面兩個(gè)synchronized方法,兩個(gè)線程同時(shí)訪問(wèn)的問(wèn)題
  22. volatile的原理
  23. 談?wù)剉olatile關(guān)鍵字的用法
  24. 談?wù)剉olatile關(guān)鍵字的作用
  25. 談?wù)凬IO的理解
  26. synchronized 和volatile 關(guān)鍵字的區(qū)別
  27. synchronized與Lock的區(qū)別
  28. ReentrantLock 、synchronized和volatile比較
  29. ReentrantLock的內(nèi)部實(shí)現(xiàn)
  30. lock原理
  31. 死鎖的四個(gè)必要條件?
  32. 怎么避免死鎖?
  33. 對(duì)象鎖和類(lèi)鎖是否會(huì)互相影響?
  34. 什么是線程池,如何使用?
  35. Java的并發(fā)、多線程、線程模型
  36. 談?wù)剬?duì)多線程的理解
  37. 多線程有什么要注意的問(wèn)題?
  38. 談?wù)勀銓?duì)并發(fā)編程的理解并舉例說(shuō)明
  39. 談?wù)勀銓?duì)多線程同步機(jī)制的理解?
  40. 如何保證多線程讀寫(xiě)文件的安全?
  41. 多線程斷點(diǎn)續(xù)傳原理
  42. 斷點(diǎn)續(xù)傳的實(shí)現(xiàn)

(五)并發(fā)編程有關(guān)知識(shí)點(diǎn)(這個(gè)是一般Android開(kāi)發(fā)用的少的,所以建議多去看看):

平時(shí)Android開(kāi)發(fā)中對(duì)并發(fā)編程可以做得比較少,Thread這個(gè)類(lèi)經(jīng)常會(huì)用到,但是我們想提升自己的話,一定不能停留在表面,,我們也應(yīng)該去了解一下java的關(guān)于線程相關(guān)的源碼級(jí)別的東西。

二、Android面試題

Android面試題包括Android基礎(chǔ),還有一些源碼級(jí)別的、原理這些等。所以想去大公司面試,一定要多看看源碼和實(shí)現(xiàn)方式,常用框架可以試試自己能不能手寫(xiě)實(shí)現(xiàn)一下,鍛煉一下自己。

(一)Android基礎(chǔ)知識(shí)點(diǎn)

  1. 四大組件是什么
  2. 四大組件的生命周期和簡(jiǎn)單用法
  3. Activity之間的通信方式
  4. Activity各種情況下的生命周期
  5. 橫豎屏切換的時(shí)候,Activity 各種情況下的生命周期
  6. Activity與Fragment之間生命周期比較
  7. Activity上有Dialog的時(shí)候按Home鍵時(shí)的生命周期
  8. 兩個(gè)Activity 之間跳轉(zhuǎn)時(shí)必然會(huì)執(zhí)行的是哪幾個(gè)方法?
  9. 前臺(tái)切換到后臺(tái),然后再回到前臺(tái),Activity生命周期回調(diào)方法。彈出Dialog,生命值周期回調(diào)方法。
  10. Activity的四種啟動(dòng)模式對(duì)比
  11. Activity狀態(tài)保存于恢復(fù)
  12. fragment各種情況下的生命周期
  13. Fragment狀態(tài)保存startActivityForResult是哪個(gè)類(lèi)的方法,在什么情況下使用?
  14. 如何實(shí)現(xiàn)Fragment的滑動(dòng)?
  15. fragment之間傳遞數(shù)據(jù)的方式?
  16. Activity 怎么和Service 綁定?
  17. 怎么在Activity 中啟動(dòng)自己對(duì)應(yīng)的Service?
  18. service和activity怎么進(jìn)行數(shù)據(jù)交互?
  19. Service的開(kāi)啟方式
  20. 請(qǐng)描述一下Service 的生命周期
  21. 談?wù)勀銓?duì)ContentProvider的理解
  22. 說(shuō)說(shuō)ContentProvider、ContentResolver、ContentObserver 之間的關(guān)系
  23. 請(qǐng)描述一下廣播BroadcastReceiver的理解
  24. 廣播的分類(lèi)
  25. 廣播使用的方式和場(chǎng)景
  26. 在manifest 和代碼中如何注冊(cè)和使用BroadcastReceiver?
  27. 本地廣播和全局廣播有什么差別?
  28. BroadcastReceiver,LocalBroadcastReceiver 區(qū)別
  29. AlertDialog,popupWindow,Activity區(qū)別
  30. Application 和 Activity 的 Context 對(duì)象的區(qū)別
  31. Android屬性動(dòng)畫(huà)特性
  32. 如何導(dǎo)入外部數(shù)據(jù)庫(kù)?
  33. LinearLayout、RelativeLayout、FrameLayout的特性及對(duì)比,并介紹使用場(chǎng)景。
  34. 談?wù)剬?duì)接口與回調(diào)的理解
  35. 回調(diào)的原理
  36. 寫(xiě)一個(gè)回調(diào)demo
  37. 介紹下SurfView
  38. RecycleView的使用
  39. 序列化的作用,以及Android兩種序列化的區(qū)別
  40. 差值器
  41. 估值器
  42. Android中數(shù)據(jù)存儲(chǔ)方式

(二)Android源碼相關(guān)分析

  1. Android動(dòng)畫(huà)框架實(shí)現(xiàn)原理
  2. Android各個(gè)版本API的區(qū)別
  3. Requestlayout,onlayout,onDraw,DrawChild區(qū)別與聯(lián)系
  4. invalidate和postInvalidate的區(qū)別及使用
  5. Activity-Window-View三者的差別
  6. 談?wù)剬?duì)Volley的理解
  7. 如何優(yōu)化自定義View
  8. 低版本SDK如何實(shí)現(xiàn)高版本api?
  9. 描述一次網(wǎng)絡(luò)請(qǐng)求的流程
  10. HttpUrlConnection 和 okhttp關(guān)系
  11. Bitmap對(duì)象的理解
  12. looper架構(gòu)
  13. ActivityThread,AMS,WMS的工作原理
  14. 自定義View如何考慮機(jī)型適配
  15. 自定義View的事件
  16. AstncTask+HttpClient 與 AsyncHttpClient有什么區(qū)別?
  17. LaunchMode應(yīng)用場(chǎng)景
  18. AsyncTask 如何使用?
  19. SpareArray原理
  20. 請(qǐng)介紹下ContentProvider 是如何實(shí)現(xiàn)數(shù)據(jù)共享的?
  21. AndroidService與Activity之間通信的幾種方式
  22. IntentService原理及作用是什么?
  23. 說(shuō)說(shuō)Activity、Intent、Service 是什么關(guān)系
  24. ApplicationContext和ActivityContext的區(qū)別
  25. SP是進(jìn)程同步的嗎?有什么方法做到同步?
  26. 談?wù)劧嗑€程在Android中的使用
  27. 進(jìn)程和 Application 的生命周期
  28. 封裝View的時(shí)候怎么知道view的大小
  29. RecycleView原理
  30. AndroidManifest的作用與理解

(三)常見(jiàn)的一些原理性問(wèn)題

  1. Handler機(jī)制和底層實(shí)現(xiàn)
  2. Handler、Thread和HandlerThread的差別
  3. handler發(fā)消息給子線程,looper怎么啟動(dòng)?
  4. 關(guān)于Handler,在任何地方new Handler 都是什么線程下?
  5. ThreadLocal原理,實(shí)現(xiàn)及如何保證Local屬性?
  6. 請(qǐng)解釋下在單線程模型中Message、Handler、Message Queue、Looper之間的關(guān)系
  7. 請(qǐng)描述一下View事件傳遞分發(fā)機(jī)制
  8. Touch事件傳遞流程
  9. 事件分發(fā)中的onTouch 和onTouchEvent 有什么區(qū)別,又該如何使用?
  10. View和ViewGroup分別有哪些事件分發(fā)相關(guān)的回調(diào)方法
  11. View刷新機(jī)制
  12. View繪制流程
  13. 自定義控件原理
  14. 自定義View如何提供獲取View屬性的接口?
  15. Android代碼中實(shí)現(xiàn)WAP方式聯(lián)網(wǎng)
  16. AsyncTask機(jī)制
  17. AsyncTask原理及不足
  18. 如何取消AsyncTask?
  19. 為什么不能在子線程更新UI?
  20. ANR產(chǎn)生的原因是什么?
  21. ANR定位和修正
  22. oom是什么?
  23. 什么情況導(dǎo)致oom?
  24. 有什么解決方法可以避免OOM?
  25. Oom 是否可以try catch?為什么?
  26. 內(nèi)存泄漏是什么?
  27. 什么情況導(dǎo)致內(nèi)存泄漏?
  28. 如何防止線程的內(nèi)存泄漏?
  29. 內(nèi)存泄露場(chǎng)的解決方法
  30. 內(nèi)存泄漏和內(nèi)存溢出區(qū)別?
  31. LruCache默認(rèn)緩存大小
  32. ContentProvider的權(quán)限管理(解答:讀寫(xiě)分離,權(quán)限控制-精確到表級(jí),URL控制)
  33. 如何通過(guò)廣播攔截和abort一條短信?
  34. 廣播是否可以請(qǐng)求網(wǎng)絡(luò)?
  35. 廣播引起anr的時(shí)間限制是多少?
  36. 計(jì)算一個(gè)view的嵌套層級(jí)
  37. Activity棧
  38. Android線程有沒(méi)有上限?
  39. 線程池有沒(méi)有上限?
  40. ListView重用的是什么?
  41. Android為什么引入Parcelable?
  42. 有沒(méi)有嘗試簡(jiǎn)化Parcelable的使用?

(四)開(kāi)發(fā)中常見(jiàn)的一些問(wèn)題

  1. ListView 中圖片錯(cuò)位的問(wèn)題是如何產(chǎn)生的?
  2. 混合開(kāi)發(fā)有了解嗎?
  3. 知道哪些混合開(kāi)發(fā)的方式?說(shuō)出它們的優(yōu)缺點(diǎn)和各自使用場(chǎng)景?(解答:比如:RN,weex,H5,小程序,WPA等。做Android的了解一些前端js等還是很有好處的);
  4. 屏幕適配的處理技巧都有哪些?
  5. 服務(wù)器只提供數(shù)據(jù)接收接口,在多線程或多進(jìn)程條件下,如何保證數(shù)據(jù)的有序到達(dá)?
  6. 動(dòng)態(tài)布局的理解
  7. 怎么去除重復(fù)代碼?
  8. 畫(huà)出 Android 的大體架構(gòu)圖
  9. Recycleview和ListView的區(qū)別
  10. ListView圖片加載錯(cuò)亂的原理和解決方案
  11. 動(dòng)態(tài)權(quán)限適配方案,權(quán)限組的概念
  12. Android系統(tǒng)為什么會(huì)設(shè)計(jì)ContentProvider?
  13. 下拉狀態(tài)欄是不是影響activity的生命周期
  14. 如果在onStop的時(shí)候做了網(wǎng)絡(luò)請(qǐng)求,onResume的時(shí)候怎么恢復(fù)?
  15. Bitmap 使用時(shí)候注意什么?
  16. Bitmap的recycler()
  17. Android中開(kāi)啟攝像頭的主要步驟
  18. ViewPager使用細(xì)節(jié),如何設(shè)置成每次只初始化當(dāng)前的Fragment,其他的不初始化?
  19. 點(diǎn)擊事件被攔截,但是想傳到下面的View,如何操作?
  20. 微信主頁(yè)面的實(shí)現(xiàn)方式
  21. 微信上消息小紅點(diǎn)的原理
  22. CAS介紹

三、混合開(kāi)發(fā)面試題

大廠除了技術(shù)深度之外,還要求你具備一些廣度的知識(shí),比如你要會(huì)前端知識(shí),會(huì)混合開(kāi)發(fā),至少會(huì)一種腳本語(yǔ)言,C c++更不用說(shuō)了,也是必會(huì)的。

  1. Hybrid做過(guò)嗎?
  2. Hybrid通信原理是什么,有做研究嗎?
  3. react native有多少了解?講一下原理。
  4. weex了解嗎?如何自己實(shí)現(xiàn)類(lèi)似技術(shù)?
  5. flutter了解嗎??jī)?nèi)部是如何實(shí)現(xiàn)跨平臺(tái)的?
  6. Dart語(yǔ)言有研究貴嗎?
  7. 快應(yīng)用了解嗎?跟其她方式相比有什么優(yōu)缺點(diǎn)?
  8. 說(shuō)說(shuō)你用過(guò)的混合開(kāi)發(fā)技術(shù)有哪些?各有什么優(yōu)缺點(diǎn)?
  9. Python會(huì)嗎?
  10. 會(huì)不會(huì)PHP?
  11. Gradle了解多少?groovy語(yǔ)法會(huì)嗎?

如果有想學(xué)習(xí)Java架構(gòu)技術(shù)的朋友們可以加入我的進(jìn)階架構(gòu)學(xué)習(xí)群:909666042 ,群內(nèi)會(huì)有一些架構(gòu)學(xué)習(xí)視頻、資料以及書(shū)籍分享給大家。

四、高端技術(shù)面試題

這里講的是大公司需要用到的一些高端Android技術(shù),這里專(zhuān)門(mén)整理了一個(gè)文檔,希望大家都可以看看。這些題目有點(diǎn)技術(shù)含量,需要好點(diǎn)時(shí)間去研究一下的。

(一)圖片

  1. 圖片庫(kù)對(duì)比
  2. 圖片庫(kù)的源碼分析
  3. 圖片框架緩存實(shí)現(xiàn)
  4. LRUCache原理
  5. 圖片加載原理
  6. 自己去實(shí)現(xiàn)圖片庫(kù),怎么做?
  7. Glide源碼解析
  8. Glide使用什么緩存?
  9. Glide內(nèi)存緩存如何控制大???

(二)網(wǎng)絡(luò)和安全機(jī)制

  1. 網(wǎng)絡(luò)框架對(duì)比和源碼分析
  2. 自己去設(shè)計(jì)網(wǎng)絡(luò)請(qǐng)求框架,怎么做?
  3. okhttp源碼
  4. 網(wǎng)絡(luò)請(qǐng)求緩存處理,okhttp如何處理網(wǎng)絡(luò)緩存的
  5. 從網(wǎng)絡(luò)加載一個(gè)10M的圖片,說(shuō)下注意事項(xiàng)
  6. TCP的3次握手和四次揮手
  7. TCP與UDP的區(qū)別
  8. TCP與UDP的應(yīng)用
  9. HTTP協(xié)議
  10. HTTP1.0與2.0的區(qū)別
  11. HTTP報(bào)文結(jié)構(gòu)
  12. HTTP與HTTPS的區(qū)別以及如何實(shí)現(xiàn)安全性
  13. 如何驗(yàn)證證書(shū)的合法性?
  14. https中哪里用了對(duì)稱(chēng)加密,哪里用了非對(duì)稱(chēng)加密,對(duì)加密算法(如RSA)等是否有了解?
  15. client如何確定自己發(fā)送的消息被server收到?
  16. 談?wù)勀銓?duì)WebSocket的理解
  17. WebSocket與socket的區(qū)別
  18. 談?wù)勀銓?duì)安卓簽名的理解。
  19. 請(qǐng)解釋安卓為啥要加簽名機(jī)制?
  20. 視頻加密傳輸
  21. App 是如何沙箱化,為什么要這么做?
  22. 權(quán)限管理系統(tǒng)(底層的權(quán)限是如何進(jìn)行 grant 的)?

(三)數(shù)據(jù)庫(kù)

  1. sqlite升級(jí),增加字段的語(yǔ)句
  2. 數(shù)據(jù)庫(kù)框架對(duì)比和源碼分析
  3. 數(shù)據(jù)庫(kù)的優(yōu)化
  4. 數(shù)據(jù)庫(kù)數(shù)據(jù)遷移問(wèn)題

(四)算法

  1. 排序算法有哪些?
  2. 最快的排序算法是哪個(gè)?
  3. 手寫(xiě)一個(gè)冒泡排序
  4. 手寫(xiě)快速排序代碼
  5. 快速排序的過(guò)程、時(shí)間復(fù)雜度、空間復(fù)雜度
  6. 手寫(xiě)堆排序
  7. 堆排序過(guò)程、時(shí)間復(fù)雜度及空間復(fù)雜度
  8. 寫(xiě)出你所知道的排序算法及時(shí)空復(fù)雜度,穩(wěn)定性
  9. 二叉樹(shù)給出根節(jié)點(diǎn)和目標(biāo)節(jié)點(diǎn),找出從根節(jié)點(diǎn)到目標(biāo)節(jié)點(diǎn)的路徑
  10. 給阿里2萬(wàn)多名員工按年齡排序應(yīng)該選擇哪個(gè)算法?
  11. GC算法(各種算法的優(yōu)缺點(diǎn)以及應(yīng)用場(chǎng)景)
  12. 蟻群算法與蒙特卡洛算法
  13. 子串包含問(wèn)題(KMP 算法)寫(xiě)代碼實(shí)現(xiàn)
  14. 一個(gè)無(wú)序,不重復(fù)數(shù)組,輸出N個(gè)元素,使得N個(gè)元素的和相加為M,給出時(shí)間復(fù)雜度、空間復(fù)雜度。手寫(xiě)算法
  15. 萬(wàn)億級(jí)別的兩個(gè)URL文件A和B,如何求出A和B的差集C(提示:Bit映射->hash分組->多文件讀寫(xiě)效率->磁盤(pán)尋址以及應(yīng)用層面對(duì)尋址的優(yōu)化)
  16. 百度POI中如何試下查找最近的商家功能(提示:坐標(biāo)鏡像+R樹(shù))。
  17. 兩個(gè)不重復(fù)的數(shù)組集合中,求共同的元素。
  18. 兩個(gè)不重復(fù)的數(shù)組集合中,這兩個(gè)集合都是海量數(shù)據(jù),內(nèi)存中放不下,怎么求共同的元素?
  19. 一個(gè)文件中有100萬(wàn)個(gè)整數(shù),由空格分開(kāi),在程序中判斷用戶輸入的整數(shù)是否在此文件中。說(shuō)出最優(yōu)的方法
  20. 一張Bitmap所占內(nèi)存以及內(nèi)存占用的計(jì)算
  21. 2000萬(wàn)個(gè)整數(shù),找出第五十大的數(shù)字?
  22. 燒一根不均勻的繩,從頭燒到尾總共需要1個(gè)小時(shí)。現(xiàn)在有若干條材質(zhì)相同的繩子,問(wèn)如何用燒繩的方法來(lái)計(jì)時(shí)一個(gè)小時(shí)十五分鐘呢?
  23. 求1000以內(nèi)的水仙花數(shù)以及40億以內(nèi)的水仙花數(shù)
  24. 5枚硬幣,2正3反如何劃分為兩堆然后通過(guò)翻轉(zhuǎn)讓兩堆中正面向上的硬8幣和反面向上的硬幣個(gè)數(shù)相同
  25. 時(shí)針走一圈,時(shí)針?lè)轴樦睾蠋状?/li>
  26. N*N的方格紙,里面有多少個(gè)正方形
  27. x個(gè)蘋(píng)果,一天只能吃一個(gè)、兩個(gè)、或者三個(gè),問(wèn)多少天可以吃完?

(五)插件化、模塊化、組件化、熱修復(fù)、增量更新、Gradle

  1. 對(duì)熱修復(fù)和插件化的理解
  2. 插件化原理分析
  3. 模塊化實(shí)現(xiàn)(好處,原因)
  4. 熱修復(fù),插件化
  5. 項(xiàng)目組件化的理解
  6. 描述清點(diǎn)擊 Android Studio 的 build 按鈕后發(fā)生了什么

(六)架構(gòu)設(shè)計(jì)和設(shè)計(jì)模式

  1. 談?wù)勀銓?duì)Android設(shè)計(jì)模式的理解
  2. MVC MVP MVVM原理和區(qū)別
  3. 你所知道的設(shè)計(jì)模式有哪些?
  4. 項(xiàng)目中常用的設(shè)計(jì)模式
  5. 手寫(xiě)生產(chǎn)者/消費(fèi)者模式
  6. 寫(xiě)出觀察者模式的代碼
  7. 適配器模式,裝飾者模式,外觀模式的異同?
  8. 用到的一些開(kāi)源框架,介紹一個(gè)看過(guò)源碼的,內(nèi)部實(shí)現(xiàn)過(guò)程。
  9. 談?wù)剬?duì)RxJava的理解
  10. RxJava的功能與原理實(shí)現(xiàn)
  11. RxJava的作用,與平時(shí)使用的異步操作來(lái)比的優(yōu)缺點(diǎn)
  12. 說(shuō)說(shuō)EventBus作用,實(shí)現(xiàn)方式,代替EventBus的方式
  13. 從0設(shè)計(jì)一款A(yù)pp整體架構(gòu),如何去做?
  14. 說(shuō)一款你認(rèn)為當(dāng)前比較火的應(yīng)用并設(shè)計(jì)(比如:直播APP,P2P金融,小視頻等)
  15. 談?wù)剬?duì)java狀態(tài)機(jī)理解
  16. Fragment如果在Adapter中使用應(yīng)該如何解耦?
  17. Binder機(jī)制及底層實(shí)現(xiàn)
  18. 對(duì)于應(yīng)用更新這塊是如何做的?(解答:灰度,強(qiáng)制更新,分區(qū)域更新)?
  19. 實(shí)現(xiàn)一個(gè)Json解析器(可以通過(guò)正則提高速度)
  20. 統(tǒng)計(jì)啟動(dòng)時(shí)長(zhǎng),標(biāo)準(zhǔn)

(七)性能優(yōu)化

  1. 如何對(duì)Android 應(yīng)用進(jìn)行性能分析以及優(yōu)化?
  2. ddms 和 traceView
  3. 性能優(yōu)化如何分析systrace?
  4. 用IDE如何分析內(nèi)存泄漏?
  5. Java多線程引發(fā)的性能問(wèn)題,怎么解決?
  6. 啟動(dòng)頁(yè)白屏及黑屏解決?
  7. 啟動(dòng)太慢怎么解決?
  8. 怎么保證應(yīng)用啟動(dòng)不卡頓?
  9. App啟動(dòng)崩潰異常捕捉
  10. 自定義View注意事項(xiàng)
  11. 現(xiàn)在下載速度很慢,試從網(wǎng)絡(luò)協(xié)議的角度分析原因,并優(yōu)化(提示:網(wǎng)絡(luò)的5層都可以涉及)。
  12. Https請(qǐng)求慢的解決辦法(提示:DNS,攜帶數(shù)據(jù),直接訪問(wèn)IP)
  13. 如何保持應(yīng)用的穩(wěn)定性
  14. RecyclerView和ListView的性能對(duì)比
  15. ListView的優(yōu)化
  16. RecycleView優(yōu)化
  17. View渲染
  18. Bitmap如何處理大圖,如一張30M的大圖,如何預(yù)防OOM
  19. java中的四種引用的區(qū)別以及使用場(chǎng)景
  20. 強(qiáng)引用置為null,會(huì)不會(huì)被回收?

(八)NDK、jni、Binder、AIDL、進(jìn)程通信有關(guān)

  1. 請(qǐng)介紹一下NDK
  2. 什么是NDK庫(kù)?
  3. jni用過(guò)嗎?
  4. 如何在jni中注冊(cè)native函數(shù),有幾種注冊(cè)方式?
  5. Java如何調(diào)用c、c++語(yǔ)言?
  6. jni如何調(diào)用java層代碼?
  7. 進(jìn)程間通信的方式?
  8. Binder機(jī)制
  9. 簡(jiǎn)述IPC?
  10. 什么是AIDL?
  11. AIDL解決了什么問(wèn)題?
  12. AIDL如何使用?
  13. Android 上的 Inter-Process-Communication 跨進(jìn)程通信時(shí)如何工作的?
  14. 多進(jìn)程場(chǎng)景遇見(jiàn)過(guò)么?
  15. Android進(jìn)程分類(lèi)?
  16. 進(jìn)程和 Application 的生命周期?
  17. 進(jìn)程調(diào)度
  18. 談?wù)剬?duì)進(jìn)程共享和線程安全的認(rèn)識(shí)
  19. 談?wù)剬?duì)多進(jìn)程開(kāi)發(fā)的理解以及多進(jìn)程應(yīng)用場(chǎng)景
  20. 什么是協(xié)程?

(九)framework層、ROM定制、Ubuntu、Linux之類(lèi)的問(wèn)題

  1. java虛擬機(jī)的特性
  2. 談?wù)剬?duì)jvm的理解
  3. JVM內(nèi)存區(qū)域,開(kāi)線程影響哪塊內(nèi)存
  4. 對(duì)Dalvik、ART虛擬機(jī)有什么了解?
  5. Art和Dalvik對(duì)比
  6. 虛擬機(jī)原理,如何自己設(shè)計(jì)一個(gè)虛擬機(jī)(內(nèi)存管理,類(lèi)加載,雙親委派)
  7. 談?wù)勀銓?duì)雙親委派模型理解
  8. JVM內(nèi)存模型,內(nèi)存區(qū)域
  9. 類(lèi)加載機(jī)制
  10. 談?wù)剬?duì)ClassLoader(類(lèi)加載器)的理解
  11. 談?wù)剬?duì)動(dòng)態(tài)加載(OSGI)的理解
  12. 內(nèi)存對(duì)象的循環(huán)引用及避免
  13. 內(nèi)存回收機(jī)制、GC回收策略、GC原理時(shí)機(jī)以及GC對(duì)象
  14. 垃圾回收機(jī)制與調(diào)用System.gc()區(qū)別
  15. Ubuntu編譯安卓系統(tǒng)
  16. 系統(tǒng)啟動(dòng)流程是什么?(提示:Zygote進(jìn)程 –> SystemServer進(jìn)程 –> 各種系統(tǒng)服務(wù) –> 應(yīng)用進(jìn)程)
  17. 大體說(shuō)清一個(gè)應(yīng)用程序安裝到手機(jī)上時(shí)發(fā)生了什么
  18. 簡(jiǎn)述Activity啟動(dòng)全部過(guò)程
  19. App啟動(dòng)流程,從點(diǎn)擊桌面開(kāi)始
  20. 邏輯地址與物理地址,為什么使用邏輯地址?
  21. Android為每個(gè)應(yīng)用程序分配的內(nèi)存大小是多少?
  22. Android中進(jìn)程內(nèi)存的分配,能不能自己分配定額內(nèi)存?
  23. 進(jìn)程?;畹姆绞?/li>
  24. 如何保證一個(gè)后臺(tái)服務(wù)不被殺死?(相同問(wèn)題:如何保證service在后臺(tái)不被kill?)比較省電的方式是什么?
  25. App中喚醒其他進(jìn)程的實(shí)現(xiàn)方式

五、非技術(shù)性問(wèn)題&HR問(wèn)題匯總

這里整理的是一些與技術(shù)沒(méi)有直接關(guān)系的面試題,但是能夠考察你的綜合水平,所以不要以為不是技術(shù)問(wèn)題,就不看,往往有時(shí)候就是這樣一些細(xì)節(jié)的題目被忽視,而錯(cuò)過(guò)了一次次面試機(jī)會(huì)。

(一)非技術(shù)問(wèn)題

  1. 介紹你做過(guò)的哪些項(xiàng)目
  2. 都使用過(guò)哪些框架、平臺(tái)?
  3. 都使用過(guò)哪些自定義控件?
  4. 研究比較深入的領(lǐng)域有哪些?
  5. 對(duì)業(yè)內(nèi)信息的關(guān)注渠道有哪些?
  6. 最近都讀哪些書(shū)?
  7. 有沒(méi)有什么開(kāi)源項(xiàng)目?
  8. 自己最擅長(zhǎng)的技術(shù)點(diǎn),最感興趣的技術(shù)領(lǐng)域和技術(shù)點(diǎn)
  9. 項(xiàng)目中用了哪些開(kāi)源庫(kù),如何避免因?yàn)橐腴_(kāi)源庫(kù)而導(dǎo)致的安全性和穩(wěn)定性問(wèn)題
  10. 實(shí)習(xí)過(guò)程中做了什么,有什么產(chǎn)出?

(二)HR提出的面試問(wèn)題

  1. 您在前一家公司的離職原因是什么?
  2. 講一件你印象最深的一件事情
  3. 介紹一個(gè)你影響最深的項(xiàng)目
  4. 介紹你最熱愛(ài)最擅長(zhǎng)的專(zhuān)業(yè)領(lǐng)域
  5. 公司實(shí)習(xí)最大的收獲是什么?
  6. 與上級(jí)意見(jiàn)不一致時(shí),你將怎么辦?
  7. 自己的優(yōu)點(diǎn)和缺點(diǎn)是什么?并舉例說(shuō)明?
  8. 你的學(xué)習(xí)方法是什么樣的?實(shí)習(xí)過(guò)程中如何學(xué)習(xí)?實(shí)習(xí)項(xiàng)目中遇到的最大困難是什么以及如何解決的?
  9. 說(shuō)一件最能證明你能力的事情
  10. 針對(duì)你你申請(qǐng)的這個(gè)職位,你認(rèn)為你還欠缺什么
  11. 如果通過(guò)這次面試我們單位錄用了你,但工作一段時(shí)間卻發(fā)現(xiàn)你根本不適合這個(gè)職位,你怎么辦?
  12. 項(xiàng)目中遇到最大的困難是什么?如何解決的?
  13. 你的職業(yè)規(guī)劃以及個(gè)人目標(biāo)、未來(lái)發(fā)展路線及求職定位
  14. 如果你在這次面試中沒(méi)有被錄用,你怎么打算?
  15. 評(píng)價(jià)下自己,評(píng)價(jià)下自己的技術(shù)水平,個(gè)人代碼量如何?
  16. 通過(guò)哪些渠道了解的招聘信息,其他同學(xué)都投了哪些公司?
  17. 業(yè)余都有哪些愛(ài)好?
  18. 你做過(guò)的哪件事最令自己感到驕傲?
  19. 假如你晚上要去送一個(gè)出國(guó)的同學(xué)去機(jī)場(chǎng),可單位臨時(shí)有事非你辦不可,你怎么辦?
  20. 就你申請(qǐng)的這個(gè)職位,你認(rèn)為你還欠缺什么?
  21. 當(dāng)前的offer狀況;如果BATH都給了offer該如何選?
  22. 你對(duì)一份工作更看重哪些方面?平臺(tái),技術(shù),氛圍,城市,還是money?
  23. 理想薪資范圍;杭州崗和北京崗選哪個(gè)?
  24. 理想中的工作環(huán)境是什么?
  25. 談?wù)勀銓?duì)跳槽的看法
  26. 說(shuō)說(shuō)你對(duì)行業(yè)、技術(shù)發(fā)展趨勢(shì)的看法
  27. 實(shí)習(xí)過(guò)程中周?chē)?同學(xué)有哪些值得學(xué)習(xí)的地方?
  28. 家人對(duì)你的工作期望及自己的工作期望
  29. 如果你的工作出現(xiàn)失誤,給本公司造成經(jīng)濟(jì)損失,你認(rèn)為該怎么辦?
  30. 若上司在公開(kāi)會(huì)議上誤會(huì)你了,該如何解決?
  31. 是否可以實(shí)習(xí),可以實(shí)習(xí)多久?
  32. 在五年的時(shí)間內(nèi),你的職業(yè)規(guī)劃
  33. 你看中公司的什么?或者公司的那些方面最吸引你?

資料分享

包括但不限于:分布式架構(gòu)、高可擴(kuò)展、高性能、高并發(fā)、Jvm性能調(diào)優(yōu)、Spring,MyBatis,Nginx源碼分析,Redis,ActiveMQ、Mycat、Netty、Kafka、Mysql、Zookeeper、Tomcat、Docker、Dubbo、Nginx等多個(gè)知識(shí)點(diǎn)高級(jí)進(jìn)階干貨

領(lǐng)取方式:進(jìn)我的學(xué)習(xí)交流群:909666042 免費(fèi)獲??!

為什么某些人會(huì)一直比你優(yōu)秀,是因?yàn)樗旧砭秃軆?yōu)秀還一直在持續(xù)努力變得更優(yōu)秀。而你是不是還在滿足于現(xiàn)狀內(nèi)心在竊喜?“對(duì)于程序員來(lái)說(shuō),如果哪一天開(kāi)始他停止了學(xué)習(xí),那么他的職業(yè)生涯便開(kāi)始宣告消亡。”所以行動(dòng)起來(lái),學(xué)習(xí)起來(lái)!

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請(qǐng)結(jié)合常識(shí)與多方信息審慎甄別。
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡(jiǎn)書(shū)系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。

友情鏈接更多精彩內(nèi)容