金三銀四熱潮下。Android高級工程師面試題整理

最近整理了一波面試題,包括安卓JAVA方面的,目前大廠仍是以安卓源碼,算法,以及數據結構爲主,有一些中小型公司也會問到混合開發的知識,至於我爲何傾向於混合開發,個人一句話就是"走上編程之路,未來你要學不只僅是這些,豐富本身方能與世接軌",作好全棧的裝備。

前言

金三銀四,不少同窗內心大概都準備着年後找工做或者跳槽。最近有不少同窗都在交流羣裏求大廠面試題。正好我電腦裏面有這方面的整理,因而就發上來分享給你們。前端

這些題目是朋友去百度、小米、樂視、美團、5八、獵豹、360、新浪、搜狐等一線互聯網公司面試被問到的題目。熟悉本文中列出的知識點會大大增長經過前兩輪技術面試的概率。java

而且整理成了一份學習筆記(VX:mm14525201314)

視頻擴展:c++

kotlin(視頻): https://github.com/xiangjiana/Android-MS
flutter(視頻): https://github.com/xiangjiana/Android-MS
音視頻高手開發從0開始認識(視頻):
https://github.com/xiangjiana/Android-MS

主要分爲如下幾部分:

(1)java面試題
(2)Android面試題
(3)高級開發技術面試題
(4)跨平臺Hybrid 開發

1、java面試題

熟練掌握java是很關鍵的,大公司不只僅要求你會使用幾個api,更多的是要你熟悉源碼實現原理,甚至要你知道有哪些不足,怎麼改進,還有一些java有關的一些算法,設計模式等等。git

(一) java基礎面試知識點

  • java中==和equals和hashCode的區別
  • int、char、long各佔多少字節數
  • int與integer的區別
  • 探探對java多態的理解
  • String、StringBuffer、StringBuilder區別
  • 什麼是內部類?內部類的做用
  • 抽象類和接口區別
  • 抽象類的意義
  • 抽象類與接口的應用場景
  • 抽象類是否能夠沒有方法和屬性?
  • 接口的意義
  • 泛型中extends和super的區別
  • 父類的靜態方法可否被子類重寫
  • 進程和線程的區別
  • final,finally,finalize的區別
  • 序列化的方式
  • Serializable 和Parcelable 的區別
  • 靜態屬性和靜態方法是否能夠被繼承?是否能夠被重寫?以及緣由?
  • 靜態內部類的設計意圖
  • 成員內部類、靜態內部類、局部內部類和匿名內部類的理解,以及項目中的應用
  • 談談對kotlin的理解
  • 閉包和局部內部類的區別
  • string 轉換成 integer的方式及原理

(二) java深刻源碼級的面試題(有難度)

  • 哪些狀況下的對象會被垃圾回收機制處理掉?
  • 講一下常見編碼方式?
  • utf-8編碼中的中文佔幾個字節;int型幾個字節?
  • 靜態代理和動態代理的區別,什麼場景使用?
  • Java的異常體系
  • 談談你對解析與分派的認識。
  • 修改對象A的equals方法的簽名,那麼使用HashMap存放這個對象實例的時候,會調用哪一個equals方法?
  • Java中實現多態的機制是什麼?
  • 如何將一個Java對象序列化到文件裏?
  • 說說你對Java反射的理解
  • 說說你對Java註解的理解
  • 說說你對依賴注入的理解
  • 說一下泛型原理,並舉例說明
  • Java中String的瞭解
  • String爲何要設計成不可變的?
  • Object類的equal和hashCode方法重寫,爲何?

(三) 數據結構

  • 經常使用數據結構簡介
  • 併發集合瞭解哪些?
  • 列舉java的集合以及集合之間的繼承關係
  • 集合類以及集合框架
  • 容器類介紹以及之間的區別(容器類估計不少人沒聽這個詞,Java容器主要能夠劃分爲4個部分:List列表、Set集合、Map映射、工具類(Iterator迭代器、Enumeration枚舉類、Arrays和Collections),具體的能夠看看這篇博文 Java容器類)
  • List,Set,Map的區別
  • List和Map的實現方式以及存儲方式
  • HashMap的實現原理
  • HashMap數據結構?
  • HashMap源碼理解
  • HashMap如何put數據(從HashMap源碼角度講解)?
  • HashMap怎麼手寫實現?
  • ConcurrentHashMap的實現原理
  • ArrayMap和HashMap的對比
  • HashTable實現原理
  • TreeMap具體實現
  • HashMap和HashTable的區別
  • HashMap與HashSet的區別
  • HashSet與HashMap怎麼判斷集合元素重複?
  • 集合Set實現Hash怎麼防止碰撞
  • ArrayList和LinkedList的區別,以及應用場景
  • 數組和鏈表的區別
  • 二叉樹的深度優先遍歷和廣度優先遍歷的具體實現
  • 堆的結構
  • 堆和樹的區別
  • 堆和棧在內存中的區別是什麼(解答提示:能夠從數據結構方面以及實際實現方面兩個方面去回答)?
  • 什麼是深拷貝和淺拷貝
  • 手寫鏈表逆序代碼
  • 講一下對樹,B+樹的理解
  • 講一下對圖的理解
  • 判斷單鏈表成環與否?
  • 鏈表翻轉(即:翻轉一個單項鍊表)
  • 合併多個單有序鏈表(假設都是遞增的)

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

  • 開啓線程的三種方式?
  • 線程和進程的區別?
  • 爲何要有線程,而不是僅僅用進程?
  • run()和start()方法區別
  • 如何控制某個方法容許併發訪問線程的個數?
  • 在Java中wait和seelp方法的不一樣;
  • 談談wait/notify關鍵字的理解
  • 什麼致使線程阻塞?
  • 線程如何關閉?
  • 講一下java中的同步的方法
  • 數據一致性如何保證?
  • 如何保證線程安全?
  • 如何實現線程同步?
  • 兩個進程同時要求寫或者讀,能不能實現?如何防止進程的同步?
  • 線程間操做List
  • Java中對象的生命週期
  • Synchronized用法
  • synchronize的原理
  • 談談對Synchronized關鍵字,類鎖,方法鎖,重入鎖的理解
  • static synchronized 方法的多線程訪問和做用
  • 同一個類裏面兩個synchronized方法,兩個線程同時訪問的問題
  • volatile的原理
  • 談談volatile關鍵字的用法
  • 談談volatile關鍵字的做用
  • 談談NIO的理解
  • synchronized 和volatile 關鍵字的區別
  • synchronized與Lock的區別
  • ReentrantLock 、synchronized和volatile比較
  • ReentrantLock的內部實現
  • lock原理
  • 死鎖的四個必要條件?
  • 怎麼避免死鎖?
  • 對象鎖和類鎖是否會互相影響?
  • 什麼是線程池,如何使用?
  • Java的併發、多線程、線程模型
  • 談談對多線程的理解
  • 多線程有什麼要注意的問題?
  • 談談你對併發編程的理解並舉例說明
  • 談談你對多線程同步機制的理解?
  • 如何保證多線程讀寫文件的安全?
  • 多線程斷點續傳原理
  • 斷點續傳的實現

(五)併發編程有關知識點(這個是通常Android開發用的少的,因此建議多去看看):

平時Android開發中對併發編程能夠作得比較少,Thread這個類常常會用到,可是咱們想提高本身的話,必定不能停留在表面,,咱們也應該去了解一下java的關於線程相關的源碼級別的東西。github

2、Android面試題

Android面試題包括Android基礎,還有一些源碼級別的、原理這些等。因此想去大公司面試,必定要多看看源碼和實現方式,經常使用框架能夠試試本身能不能手寫實現一下,鍛鍊一下本身。面試

(一)Android基礎知識點

  • 四大組件是什麼
  • 四大組件的生命週期和簡單用法
  • Activity之間的通訊方式
  • Activity各類狀況下的生命週期
  • 橫豎屏切換的時候,Activity 各類狀況下的生命週期
  • Activity與Fragment之間生命週期比較
  • Activity上有Dialog的時候按Home鍵時的生命週期
  • 兩個Activity 之間跳轉時必然會執行的是哪幾個方法?
  • 前臺切換到後臺,而後再回到前臺,Activity生命週期回調方法。彈出Dialog,生命值週期回調方法。
  • Activity的四種啓動模式對比
  • Activity狀態保存於恢復
  • fragment各類狀況下的生命週期
  • Fragment狀態保存startActivityForResult是哪一個類的方法,在什麼狀況下使用?
  • 如何實現Fragment的滑動?
  • fragment之間傳遞數據的方式?
  • Activity 怎麼和Service 綁定?
  • 怎麼在Activity 中啓動本身對應的Service?
  • service和activity怎麼進行數據交互?
  • Service的開啓方式
  • 請描述一下Service 的生命週期
  • 談談你對ContentProvider的理解
  • 說說ContentProvider、ContentResolver、ContentObserver 之間的關係
  • 請描述一下廣播BroadcastReceiver的理解
  • 廣播的分類
  • 廣播使用的方式和場景
  • 在manifest 和代碼中如何註冊和使用BroadcastReceiver?
  • 本地廣播和全局廣播有什麼差異?
  • BroadcastReceiver,LocalBroadcastReceiver 區別
  • AlertDialog,popupWindow,Activity區別
  • Application 和 Activity 的 Context 對象的區別
  • Android屬性動畫特性
  • 如何導入外部數據庫?
  • LinearLayout、RelativeLayout、FrameLayout的特性及對比,並介紹使用場景。
  • 談談對接口與回調的理解
  • 回調的原理
  • 寫一個回調demo
  • 介紹下SurfView
  • RecycleView的使用
  • 序列化的做用,以及Android兩種序列化的區別
  • 差值器
  • 估值器
  • Android中數據存儲方式

(二)Android源碼相關分析

  • Android動畫框架實現原理
  • Android各個版本API的區別
  • Requestlayout,onlayout,onDraw,DrawChild區別與聯繫
  • invalidate和postInvalidate的區別及使用
  • Activity-Window-View三者的差異
  • 談談對Volley的理解
  • 如何優化自定義View
  • 低版本SDK如何實現高版本api?
  • 描述一次網絡請求的流程
  • HttpUrlConnection 和 okhttp關係
  • Bitmap對象的理解
  • looper架構
  • ActivityThread,AMS,WMS的工做原理
  • 自定義View如何考慮機型適配
  • 自定義View的事件
  • AstncTask+HttpClient 與 AsyncHttpClient有什麼區別?
  • LaunchMode應用場景
  • AsyncTask 如何使用?
  • SpareArray原理
  • 請介紹下ContentProvider 是如何實現數據共享的?
  • AndroidService與Activity之間通訊的幾種方式
  • IntentService原理及做用是什麼?
  • 說說Activity、Intent、Service 是什麼關係
  • ApplicationContext和ActivityContext的區別
  • SP是進程同步的嗎?有什麼方法作到同步?
  • 談談多線程在Android中的使用
  • 進程和 Application 的生命週期
  • 封裝View的時候怎麼知道view的大小
  • RecycleView原理
  • AndroidManifest的做用與理解

(三)常見的一些原理性問題

  • Handler機制和底層實現
  • Handler、Thread和HandlerThread的差異
  • handler發消息給子線程,looper怎麼啓動?
  • 關於Handler,在任何地方new Handler 都是什麼線程下?
  • ThreadLocal原理,實現及如何保證Local屬性?
  • 請解釋下在單線程模型中Message、Handler、Message Queue、Looper之間的關係
  • 請描述一下View事件傳遞分發機制
  • Touch事件傳遞流程
  • 事件分發中的onTouch 和onTouchEvent 有什麼區別,又該如何使用?
  • View和ViewGroup分別有哪些事件分發相關的回調方法
  • View刷新機制
  • View繪製流程
  • 自定義控件原理
  • 自定義View如何提供獲取View屬性的接口?
  • Android代碼中實現WAP方式聯網
  • AsyncTask機制
  • AsyncTask原理及不足
  • 如何取消AsyncTask?
  • 爲何不能在子線程更新UI?
  • ANR產生的緣由是什麼?
  • ANR定位和修正
  • oom是什麼?
  • 什麼狀況致使oom?
  • 有什麼解決方法能夠避免OOM?
  • Oom 是否能夠try catch?爲何?
  • 內存泄漏是什麼?
  • 什麼狀況致使內存泄漏?
  • 如何防止線程的內存泄漏?
  • 內存泄露場的解決方法
  • 內存泄漏和內存溢出區別?
  • LruCache默認緩存大小
  • ContentProvider的權限管理(解答:讀寫分離,權限控制-精確到表級,URL控制)
  • 如何經過廣播攔截和abort一條短信?
  • 廣播是否能夠請求網絡?
  • 廣播引發anr的時間限制是多少?
  • 計算一個view的嵌套層級
  • Activity棧
  • Android線程有沒有上限?
  • 線程池有沒有上限?
  • ListView重用的是什麼?
  • Android爲何引入Parcelable?
  • 有沒有嘗試簡化Parcelable的使用?

(四)開發中常見的一些問題

  • ListView 中圖片錯位的問題是如何產生的?
  • 混合開發有了解嗎?
  • 知道哪些混合開發的方式?說出它們的優缺點和各自使用場景?(解答:好比:RN,weex,H5,小程序,WPA等。作Android的瞭解一些前- 端js等仍是頗有好處的);
  • 屏幕適配的處理技巧都有哪些?
  • 服務器只提供數據接收接口,在多線程或多進程條件下,如何保證數據的有序到達?
  • 動態佈局的理解
  • 怎麼去除重複代碼?
  • 畫出 Android 的大致架構圖
  • Recycleview和ListView的區別
  • ListView圖片加載錯亂的原理和解決方案
  • 動態權限適配方案,權限組的概念
  • Android系統爲何會設計ContentProvider?
  • 下拉狀態欄是否是影響activity的生命週期
  • 若是在onStop的時候作了網絡請求,onResume的時候怎麼恢復?
  • Bitmap 使用時候注意什麼?
  • Bitmap的recycler()
  • Android中開啓攝像頭的主要步驟
  • ViewPager使用細節,如何設置成每次只初始化當前的Fragment,其餘的不初始化?
  • 點擊事件被攔截,可是想傳到下面的View,如何操做?
  • 微信主頁面的實現方式
  • 微信上消息小紅點的原理
  • CAS介紹(這是阿里巴巴的面試題)

3、高級開發技術面試題

這裏講的是大公司須要用到的一些高端Android技術,這裏專門整理了一個文檔,但願你們均可以看看。這些題目有點技術含量,須要好點時間去研究一下的。算法

(一)圖片

  • 圖片庫對比
  • 圖片庫的源碼分析
  • 圖片框架緩存實現
  • LRUCache原理
  • 圖片加載原理
  • 本身去實現圖片庫,怎麼作?
  • Glide源碼解析
  • Glide使用什麼緩存?
  • Glide內存緩存如何控制大小?

(二)網絡和安全機制

  • 網絡框架對比和源碼分析
  • 本身去設計網絡請求框架,怎麼作?
  • okhttp源碼
  • 網絡請求緩存處理,okhttp如何處理網絡緩存的
  • 從網絡加載一個10M的圖片,說下注意事項
  • TCP的3次握手和四次揮手
  • TCP與UDP的區別
  • TCP與UDP的應用
  • HTTP協議
  • HTTP1.0與2.0的區別
  • HTTP報文結構
  • HTTP與HTTPS的區別以及如何實現安全性
  • 如何驗證證書的合法性?
  • https中哪裏用了對稱加密,哪裏用了非對稱加密,對加密算法(如RSA)等是否有了解?
  • client如何肯定本身發送的消息被server收到?
  • 談談你對WebSocket的理解
  • WebSocket與socket的區別
  • 談談你對安卓簽名的理解。
  • 請解釋安卓爲啥要加簽名機制?
  • 視頻加密傳輸
  • App 是如何沙箱化,爲何要這麼作?
  • 權限管理系統(底層的權限是如何進行 grant 的)?

(三)數據庫

  • sqlite升級,增長字段的語句
  • 數據庫框架對比和源碼分析
  • 數據庫的優化
  • 數據庫數據遷移問題

(四)算法

  • 排序算法有哪些?
  • 最快的排序算法是哪一個?
  • 手寫一個冒泡排序
  • 手寫快速排序代碼
  • 快速排序的過程、時間複雜度、空間複雜度
  • 手寫堆排序
  • 堆排序過程、時間複雜度及空間複雜度
  • 寫出你所知道的排序算法及時空複雜度,穩定性
  • 二叉樹給出根節點和目標節點,找出從根節點到目標節點的路徑
  • 給阿里2萬多名員工按年齡排序應該選擇哪一個算法?
  • GC算法(各類算法的優缺點以及應用場景)
  • 蟻羣算法與蒙特卡洛算法
  • 子串包含問題(KMP 算法)寫代碼實現
  • 一個無序,不重複數組,輸出N個元素,使得N個元素的和相加爲M,給出時間複雜度、空間複雜度。手寫算法
  • 萬億級別的兩個URL文件A和B,如何求出A和B的差集C(提示:Bit映射->hash分組->多文件讀寫效率->磁盤尋址以及應用層面對尋址的優化)
  • 百度POI中如何試下查找最近的商家功能(提示:座標鏡像+R樹)。
  • 兩個不重複的數組集合中,求共同的元素。
  • 兩個不重複的數組集合中,這兩個集合都是海量數據,內存中放不下,怎麼求共同的元素?
  • 一個文件中有100萬個整數,由空格分開,在程序中判斷用戶輸入的整數是否在此文件中。說出最優的方法
  • 一張Bitmap所佔內存以及內存佔用的計算
  • 2000萬個整數,找出第五十大的數字?
  • 燒一根不均勻的繩,從頭燒到尾總共須要1個小時。如今有若干條材質相同的繩子,問如何用燒繩的方法來計時一個小時十五分鐘呢?
  • 求1000之內的水仙花數以及40億之內的水仙花數
  • 5枚硬幣,2正3反如何劃分爲兩堆而後經過翻轉讓兩堆中正面向上的硬8幣和反面向上的硬幣個數相同
  • 時針走一圈,時針分針重合幾回
  • N*N的方格紙,裏面有多少個正方形
  • x個蘋果,一天只能吃一個、兩個、或者三個,問多少天能夠吃完?

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

  • 對熱修復和插件化的理解
  • 插件化原理分析
  • 模塊化實現(好處,緣由)
  • 熱修復,插件化
  • 項目組件化的理解
  • 描述清點擊 Android Studio 的 build 按鈕後發生了什麼

(六)架構設計和設計模式

  • 談談你對Android設計模式的理解
  • MVC MVP MVVM原理和區別
  • 你所知道的設計模式有哪些?
  • 項目中經常使用的設計模式
  • 手寫生產者/消費者模式
  • 寫出觀察者模式的代碼
  • 適配器模式,裝飾者模式,外觀模式的異同?
  • 用到的一些開源框架,介紹一個看過源碼的,內部實現過程。
  • 談談對RxJava的理解
  • RxJava的功能與原理實現
  • RxJava的做用,與平時使用的異步操做來比的優缺點
  • 說說EventBus做用,實現方式,代替EventBus的方式
  • 從0設計一款App總體架構,如何去作?
  • 說一款你認爲當前比較火的應用並設計(好比:直播APP,P2P金融,小視頻等)
  • 談談對java狀態機理解
  • Fragment若是在Adapter中使用應該如何解耦?
  • Binder機制及底層實現
  • 對於應用更新這塊是如何作的?(解答:灰度,強制更新,分區域更新)?
  • 實現一個Json解析器(能夠經過正則提升速度)
  • 統計啓動時長,標準

(七)性能優化

  • 如何對Android 應用進行性能分析以及優化?
  • ddms 和 traceView
  • 性能優化如何分析systrace?
  • 用IDE如何分析內存泄漏?
  • Java多線程引起的性能問題,怎麼解決?
  • 啓動頁白屏及黑屏解決?
  • 啓動太慢怎麼解決?
  • 怎麼保證應用啓動不卡頓?
  • App啓動崩潰異常捕捉
  • 自定義View注意事項
  • 如今下載速度很慢,試從網絡協議的角度分析緣由,並優化(提示:網絡的5層均可以涉及)。
  • Https請求慢的解決辦法(提示:DNS,攜帶數據,直接訪問IP)
  • 如何保持應用的穩定性
  • RecyclerView和ListView的性能對比
  • ListView的優化
  • RecycleView優化
  • View渲染
  • Bitmap如何處理大圖,如一張30M的大圖,如何預防OOM
  • java中的四種引用的區別以及使用場景
  • 強引用置爲null,會不會被回收?

(八)NDK、jni、Binder、AIDL、進程通訊有關

  • 請介紹一下NDK
  • 什麼是NDK庫?
  • jni用過嗎?
  • 如何在jni中註冊native函數,有幾種註冊方式?
  • Java如何調用c、c++語言?
  • jni如何調用java層代碼?
  • 進程間通訊的方式?
  • Binder機制
  • 簡述IPC?
  • 什麼是AIDL?
  • AIDL解決了什麼問題?
  • AIDL如何使用?
  • Android 上的 Inter-Process-Communication 跨進程通訊時如何工做的?
  • 多進程場景碰見過麼?
  • Android進程分類?
  • 進程和 Application 的生命週期?
  • 進程調度
  • 談談對進程共享和線程安全的認識
  • 談談對多進程開發的理解以及多進程應用場景
  • 什麼是協程?

(九)framework層、ROM定製、Ubuntu、Linux之類的問題

  • java虛擬機的特性
  • 談談對jvm的理解
  • JVM內存區域,開線程影響哪塊內存
  • 對Dalvik、ART虛擬機有什麼瞭解?
  • Art和Dalvik對比
  • 虛擬機原理,如何本身設計一個虛擬機(內存管理,類加載,雙親委派)
  • 談談你對雙親委派模型理解
  • JVM內存模型,內存區域
  • 類加載機制
  • 談談對ClassLoader(類加載器)的理解
  • 談談對動態加載(OSGI)的理解
  • 內存對象的循環引用及避免
  • 內存回收機制、GC回收策略、GC原理時機以及GC對象
  • 垃圾回收機制與調用System.gc()區別
  • Ubuntu編譯安卓系統
  • 系統啓動流程是什麼?(提示:Zygote進程 –> SystemServer進程 –> 各類系統服務 –> 應用進程)
  • 大致說清一個應用程序安裝到手機上時發生了什麼
  • 簡述Activity啓動所有過程
  • App啓動流程,從點擊桌面開始
  • 邏輯地址與物理地址,爲何使用邏輯地址?
  • Android爲每一個應用程序分配的內存大小是多少?
  • Android中進程內存的分配,能不能本身分配定額內存?
  • 進程保活的方式
  • 如何保證一個後臺服務不被殺死?(相同問題:如何保證service在後臺不被kill?)比較省電的方式是什麼?
  • App中喚醒其餘進程的實現方式

4、跨平臺Hybrid 開發

  • flutter
  • Html5項目實戰
  • HTML&CSS&JavaScript 實戰
  • WordPress搭建網站項目實戰
  • 前端Vue架構
  • 前端樣式開發
  • Weex內置能力
  • Weex原生應用
  • Weex擴展框架
  • WeexUI架構
  • 介紹你作過的哪些項目
  • 都使用過哪些框架、平臺?
  • 都使用過哪些自定義控件?
  • 研究比較深刻的領域有哪些?
  • 對業內信息的關注渠道有哪些?
  • 最近都讀哪些書?
  • 本身最擅長的技術點,最感興趣的技術領域和技術點
  • 項目中用了哪些開源庫,如何避免由於引入開源庫而致使的安全性和穩定性問題
  • 實習過程當中作了什麼,有什麼產出?

5、小結

因爲題目不少整理答案的工做量太大,因此僅限於提供知識點,若是你正在找工做,建議逐個過一遍,不懂的能夠借鑑下整理的筆記,可是請先自行上網查閱相關知識點,對於已經掌握的能夠忽略以節省時間。sql

若是對技術開發比較感興趣,能夠關注我數據庫

更多面試內容,面試專題,flutter視頻 全套,音視頻從0到高手開發。
關注 GitHub: https://github.com/xiangjiana/Android-MS
免費獲取
VX:mm14525201314
相關文章
相關標籤/搜索