2019百度,阿里面試題:Java語言+APP開發+性能優化+NDK+Flutter

前言

本文是羣裏的一位資深架構師整理出來的,這些題目是網友去百度、小米、樂視、美團、5八、獵豹、360、新浪、搜狐等一線互聯網公司面試被問到的題目。熟悉本文中列出的知識點會大大增長經過前兩輪技術面試的概率。以前網上也分享過這還沒來得及整理答案的面試題,須要答案能夠關注更新文章前端


舒適提示;本文偏長,建議勿在上班時間觀看
java

webp

面試題

一.java面試題

二.Android面試題c++

三.高級開發技術面試題web

四.跨平臺Hybrid 開發面試

1、java面試題算法

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

(一) 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+樹的理解

  • 講一下對圖的理解

  • 判斷單鏈表成環與否?

  • 鏈表翻轉(即:翻轉一個單項鍊表)

  • 合併多個單有序鏈表(假設都是遞增的)

附;數據結構算法視頻和源碼包;

webp

數據結構算法專題.png


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


  • 開啓線程的三種方式?

  • 線程和進程的區別?

  • 爲何要有線程,而不是僅僅用進程?

  • 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的關於線程相關的源碼級別的東西。

附;java進階與Android內核專題

webp


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介紹(這是阿里巴巴的面試題,我不是很瞭解,能夠參考博客: CAS簡介)

附;App開發框架知識專題.png

webp


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解析器(能夠經過正則提升速度)

  • 統計啓動時長,標準

附;移動架構項目實戰專題;

webp


(七)性能優化

  • 如何對Android 應用進行性能分析以及優化?

  • ddms 和 traceView

  • 性能優化如何分析systrace?

  • 用IDE如何分析內存泄漏?

  • Java多線程引起的性能問題,怎麼解決?

  • 啓動頁白屏及黑屏解決?

  • 啓動太慢怎麼解決?

  • 怎麼保證應用啓動不卡頓?

  • App啓動崩潰異常捕捉

  • 自定義View注意事項

  • 如今下載速度很慢,試從網絡協議的角度分析緣由,並優化(提示:網絡的5層均可以涉及)。

  • Https請求慢的解決辦法(提示:DNS,攜帶數據,直接訪問IP)

  • 如何保持應用的穩定性

  • RecyclerView和ListView的性能對比

  • ListView的優化

  • RecycleView優化

  • View渲染

  • Bitmap如何處理大圖,如一張30M的大圖,如何預防OOM

  • java中的四種引用的區別以及使用場景

  • 強引用置爲null,會不會被回收?

附;性能調優專題

webp

(八)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 的生命週期?

  • 進程調度

  • 談談對進程共享和線程安全的認識

  • 談談對多進程開發的理解以及多進程應用場景

  • 什麼是協程?

附;NDK模塊專題;

webp

(九)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架構

  • 介紹你作過的哪些項目

  • 都使用過哪些框架、平臺?

  • 都使用過哪些自定義控件?

  • 研究比較深刻的領域有哪些?

  • 對業內信息的關注渠道有哪些?

  • 最近都讀哪些書?

  • 有沒有什麼開源項目?

  • 本身最擅長的技術點,最感興趣的技術領域和技術點

  • 項目中用了哪些開源庫,如何避免由於引入開源庫而致使的安全性和穩定性問題

  • 實習過程當中作了什麼,有什麼產出?

附;跨平臺開發專題;

webp

相關文章
相關標籤/搜索