每個(gè)人都有每個(gè)人的不同登失,每個(gè)人都會(huì)有自己不同的道路遏佣。
下面的大廠面試你又是否懂了,希望你可以了解揽浙。變得更加優(yōu)秀状婶。
主要分為以下幾部分:
(1)java面試題
(2)Android面試題
(3)混合開發(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)
?java中==和equals和hashCode的區(qū)別
“==”vs"euqal ":
"hashcode”vs"euqal ":
http://www.reibang.com/writer#/notebooks/20925198/notes/34482417
?int、char跌榔、long各占多少字節(jié)數(shù)
https://blog.csdn.net/never_cxb/article/details/47204485
?int與integer的區(qū)別
https://www.cnblogs.com/liuling/archive/2013/05/05/intAndInteger.html
?談?wù)剬?duì)java多態(tài)的理解
?String异雁、StringBuffer、StringBuilder區(qū)別
簡(jiǎn)述從線程安全上看
String 不可變僧须,因此是線程安全的
StringBuilder 不是線程安全的
StringBuffer 是線程安全的纲刀,內(nèi)部使用 synchronized 進(jìn)行同步
?什么是內(nèi)部類??jī)?nèi)部類的作用
?抽象類和接口區(qū)別
?抽象類的意義
?抽象類與接口的應(yīng)用場(chǎng)景
?抽象類是否可以沒(méi)有方法和屬性担平?
?接口的意義
?泛型中extends和super的區(qū)別
?父類的靜態(tài)方法能否被子類重寫
?進(jìn)程和線程的區(qū)別
?final示绊,finally,finalize的區(qū)別
?序列化的方式
?Serializable 和Parcelable 的區(qū)別
?靜態(tài)屬性和靜態(tài)方法是否可以被繼承暂论?是否可以被重寫面褐?以及原因?
?靜態(tài)內(nèi)部類的設(shè)計(jì)意圖
?成員內(nèi)部類取胎、靜態(tài)內(nèi)部類展哭、局部?jī)?nèi)部類和匿名內(nèi)部類的理解湃窍,以及項(xiàng)目中的應(yīng)用
?談?wù)剬?duì)kotlin的理解
?閉包和局部?jī)?nèi)部類的區(qū)別
?string 轉(zhuǎn)換成 integer的方式及原理
(二) java深入源碼級(jí)的面試題(有難度)
?哪些情況下的對(duì)象會(huì)被垃圾回收機(jī)制處理掉?
?講一下常見(jiàn)編碼方式匪傍?
?utf-8編碼中的中文占幾個(gè)字節(jié)您市;int型幾個(gè)字節(jié)?
?靜態(tài)代理和動(dòng)態(tài)代理的區(qū)別役衡,什么場(chǎng)景使用茵休?
?Java的異常體系
?談?wù)勀銓?duì)解析與分派的認(rèn)識(shí)。
?修改對(duì)象A的equals方法的簽名映挂,那么使用HashMap存放這個(gè)對(duì)象實(shí)例的時(shí)候泽篮,會(huì)調(diào)用哪個(gè)equals方法?
?Java中實(shí)現(xiàn)多態(tài)的機(jī)制是什么柑船?
http://www.cnblogs.com/hupp/p/4854918.html
?如何將一個(gè)Java對(duì)象序列化到文件里帽撑?
?說(shuō)說(shuō)你對(duì)Java反射的理解
?說(shuō)說(shuō)你對(duì)Java注解的理解
?說(shuō)說(shuō)你對(duì)依賴注入的理解
?說(shuō)一下泛型原理,并舉例說(shuō)明
?Java中String的了解 ? String為什么要設(shè)計(jì)成不可變的鞍时?
https://www.programcreek.com/2013/04/why-string-is-immutable-in-java/
?Object類的equal和hashCode方法重寫亏拉,為什么?
(三) 數(shù)據(jù)結(jié)構(gòu)
?常用數(shù)據(jù)結(jié)構(gòu)簡(jiǎn)介
?并發(fā)集合了解哪些逆巍?
?列舉java的集合以及集合之間的繼承關(guān)系
?集合類以及集合框架
?容器類介紹以及之間的區(qū)別(容器類估計(jì)很多人沒(méi)聽這個(gè)詞及塘,Java容器主要可以劃分為4個(gè)部分:List列表、Set集合锐极、Map映射笙僚、工具類(Iterator迭代器、Enumeration枚舉類灵再、Arrays和Collections)肋层,具體的可以看看這篇博文 Java容器類)
?List,Set,Map的區(qū)別
?List和Map的實(shí)現(xiàn)方式以及存儲(chǔ)方式
?HashMap的實(shí)現(xiàn)原理
?HashMap數(shù)據(jù)結(jié)構(gòu)?
?HashMap源碼理解
?HashMap如何put數(shù)據(jù)(從HashMap源碼角度講解)翎迁?
?HashMap怎么手寫實(shí)現(xiàn)栋猖?
?ConcurrentHashMap的實(shí)現(xiàn)原理
?ArrayMap和HashMap的對(duì)比
?HashTable實(shí)現(xiàn)原理
?TreeMap具體實(shí)現(xiàn)
?HashMap和HashTable的區(qū)別
?HashMap與HashSet的區(qū)別
?HashSet與HashMap怎么判斷集合元素重復(fù)?
?集合Set實(shí)現(xiàn)Hash怎么防止碰撞
?ArrayList和LinkedList的區(qū)別汪榔,以及應(yīng)用場(chǎng)景
?數(shù)組和鏈表的區(qū)別
?二叉樹的深度優(yōu)先遍歷和廣度優(yōu)先遍歷的具體實(shí)現(xiàn)
?堆的結(jié)構(gòu)
?堆和樹的區(qū)別
?堆和棧在內(nèi)存中的區(qū)別是什么(解答提示:可以從數(shù)據(jù)結(jié)構(gòu)方面以及實(shí)際實(shí)現(xiàn)方面兩個(gè)方面去回答)蒲拉?
?什么是深拷貝和淺拷貝
?手寫鏈表逆序代碼
?講一下對(duì)樹,B+樹的理解
?講一下對(duì)圖的理解
?判斷單鏈表成環(huán)與否痴腌?
?鏈表翻轉(zhuǎn)(即:翻轉(zhuǎn)一個(gè)單項(xiàng)鏈表)
?合并多個(gè)單有序鏈表(假設(shè)都是遞增的)
(四) 線程雌团、多線程和線程池
?開啟線程的三種方式?
?線程和進(jìn)程的區(qū)別士聪?
?為什么要有線程锦援,而不是僅僅用進(jìn)程?
?run()和start()方法區(qū)別
?如何控制某個(gè)方法允許并發(fā)訪問(wèn)線程的個(gè)數(shù)戚嗅?
?在Java中wait和seelp方法的不同雨涛;
?談?wù)剋ait/notify關(guān)鍵字的理解
?什么導(dǎo)致線程阻塞枢舶?
?線程如何關(guān)閉?
?講一下java中的同步的方法
?數(shù)據(jù)一致性如何保證替久?
?如何保證線程安全凉泄?
?如何實(shí)現(xiàn)線程同步?
?兩個(gè)進(jìn)程同時(shí)要求寫或者讀蚯根,能不能實(shí)現(xiàn)后众?如何防止進(jìn)程的同步?
?線程間操作List
?Java中對(duì)象的生命周期
?Synchronized用法
?synchronize的原理
?談?wù)剬?duì)Synchronized關(guān)鍵字颅拦,類鎖蒂誉,方法鎖,重入鎖的理解
?static synchronized 方法的多線程訪問(wèn)和作用
?同一個(gè)類里面兩個(gè)synchronized方法距帅,兩個(gè)線程同時(shí)訪問(wèn)的問(wèn)題
?volatile的原理
?談?wù)剉olatile關(guān)鍵字的用法
?談?wù)剉olatile關(guān)鍵字的作用
?談?wù)凬IO的理解
?synchronized 和volatile 關(guān)鍵字的區(qū)別
?synchronized與Lock的區(qū)別
?ReentrantLock 右锨、synchronized和volatile比較
?ReentrantLock的內(nèi)部實(shí)現(xiàn)
?lock原理
?死鎖的四個(gè)必要條件?
?怎么避免死鎖碌秸?
?對(duì)象鎖和類鎖是否會(huì)互相影響绍移?
?什么是線程池,如何使用?
?Java的并發(fā)讥电、多線程蹂窖、線程模型
?談?wù)剬?duì)多線程的理解
?多線程有什么要注意的問(wèn)題?
?談?wù)勀銓?duì)并發(fā)編程的理解并舉例說(shuō)明
?談?wù)勀銓?duì)多線程同步機(jī)制的理解恩敌?
?如何保證多線程讀寫文件的安全瞬测?
?多線程斷點(diǎn)續(xù)傳原理
?斷點(diǎn)續(xù)傳的實(shí)現(xiàn)
(五)并發(fā)編程有關(guān)知識(shí)點(diǎn)(這個(gè)是一般Android開發(fā)用的少的,所以建議多去看看):
平時(shí)Android開發(fā)中對(duì)并發(fā)編程可以做得比較少纠炮,Thread這個(gè)類經(jīng)常會(huì)用到月趟,但是我們想提升自己的話,一定不能停留在表面抗碰,,我們也應(yīng)該去了解一下java的關(guān)于線程相關(guān)的源碼級(jí)別的東西狮斗。
學(xué)習(xí)的參考資料如下:
Java 內(nèi)存模型
?java線程安全總結(jié)
?深入理解java內(nèi)存模型系列文
并發(fā)編程:
?Java并發(fā)編程:Thread類的使用
?Java多線程編程總結(jié)
?Java并發(fā)編程的總結(jié)與思考
?Java并發(fā)編程實(shí)戰(zhàn)-----synchronized
?深入分析ConcurrentHashMap
二绽乔、Android面試題
Android面試題包括Android基礎(chǔ)弧蝇,還有一些源碼級(jí)別的、原理這些等折砸。所以想去大公司面試看疗,一定要多看看源碼和實(shí)現(xiàn)方式,常用框架可以試試自己能不能手寫實(shí)現(xiàn)一下睦授,鍛煉一下自己两芳。
(一)Android基礎(chǔ)知識(shí)點(diǎn)
?四大組件是什么
?四大組件的生命周期和簡(jiǎn)單用法
?Activity之間的通信方式
?Activity各種情況下的生命周期
?橫豎屏切換的時(shí)候,Activity 各種情況下的生命周期
?Activity與Fragment之間生命周期比較
?Activity上有Dialog的時(shí)候按Home鍵時(shí)的生命周期
?兩個(gè)Activity 之間跳轉(zhuǎn)時(shí)必然會(huì)執(zhí)行的是哪幾個(gè)方法去枷?
?前臺(tái)切換到后臺(tái)怖辆,然后再回到前臺(tái)是复,Activity生命周期回調(diào)方法。彈出Dialog竖螃,生命值周期回調(diào)方法淑廊。
?Activity的四種啟動(dòng)模式對(duì)比
?Activity狀態(tài)保存于恢復(fù)
?fragment各種情況下的生命周期
?Fragment狀態(tài)保存startActivityForResult是哪個(gè)類的方法,在什么情況下使用特咆?
?如何實(shí)現(xiàn)Fragment的滑動(dòng)腌逢?
?fragment之間傳遞數(shù)據(jù)的方式弛作?
?Activity 怎么和Service 綁定?
?怎么在Activity 中啟動(dòng)自己對(duì)應(yīng)的Service?
?service和activity怎么進(jìn)行數(shù)據(jù)交互穿挨?
?Service的開啟方式
?請(qǐng)描述一下Service 的生命周期
?談?wù)勀銓?duì)ContentProvider的理解
?說(shuō)說(shuō)ContentProvider、ContentResolver碧磅、ContentObserver 之間的關(guān)系
?請(qǐng)描述一下廣播BroadcastReceiver的理解
?廣播的分類
?廣播使用的方式和場(chǎng)景
?在manifest 和代碼中如何注冊(cè)和使用BroadcastReceiver?
?本地廣播和全局廣播有什么差別肉微?
?BroadcastReceiver,LocalBroadcastReceiver 區(qū)別
?AlertDialog,popupWindow,Activity區(qū)別
?Application 和 Activity 的 Context 對(duì)象的區(qū)別
?Android屬性動(dòng)畫特性
?如何導(dǎo)入外部數(shù)據(jù)庫(kù)?
?LinearLayout酬核、RelativeLayout脂凶、FrameLayout的特性及對(duì)比,并介紹使用場(chǎng)景愁茁。
?談?wù)剬?duì)接口與回調(diào)的理解
?回調(diào)的原理
?寫一個(gè)回調(diào)demo
?介紹下SurfView
?RecycleView的使用
?序列化的作用蚕钦,以及Android兩種序列化的區(qū)別
?差值器
?估值器
?Android中數(shù)據(jù)存儲(chǔ)方式
(二)Android源碼相關(guān)分析
?Android動(dòng)畫框架實(shí)現(xiàn)原理
?Android各個(gè)版本API的區(qū)別
?Requestlayout,onlayout鹅很,onDraw嘶居,DrawChild區(qū)別與聯(lián)系
?invalidate和postInvalidate的區(qū)別及使用
?Activity-Window-View三者的差別
?談?wù)剬?duì)Volley的理解
?如何優(yōu)化自定義View
?低版本SDK如何實(shí)現(xiàn)高版本api?
?描述一次網(wǎng)絡(luò)請(qǐng)求的流程
?HttpUrlConnection 和 okhttp關(guān)系
?Bitmap對(duì)象的理解
?looper架構(gòu)
?ActivityThread促煮,AMS邮屁,WMS的工作原理
?自定義View如何考慮機(jī)型適配
?自定義View的事件
?AstncTask+HttpClient 與 AsyncHttpClient有什么區(qū)別?
?LaunchMode應(yīng)用場(chǎng)景
?AsyncTask 如何使用?
?SpareArray原理
?請(qǐng)介紹下ContentProvider 是如何實(shí)現(xiàn)數(shù)據(jù)共享的菠齿?
?AndroidService與Activity之間通信的幾種方式
?IntentService原理及作用是什么佑吝?
?說(shuō)說(shuō)Activity、Intent绳匀、Service 是什么關(guān)系
?ApplicationContext和ActivityContext的區(qū)別
?SP是進(jìn)程同步的嗎?有什么方法做到同步芋忿?
?談?wù)劧嗑€程在Android中的使用
?進(jìn)程和 Application 的生命周期
?封裝View的時(shí)候怎么知道view的大小
?RecycleView原理
?AndroidManifest的作用與理解
(三)Android性能優(yōu)化分析
Android UI布局優(yōu)化;
(四)常見(jiàn)的一些原理性問(wèn)題
?Handler機(jī)制和底層實(shí)現(xiàn)
?Handler疾棵、Thread和HandlerThread的差別
?handler發(fā)消息給子線程戈钢,looper怎么啟動(dòng)?
?關(guān)于Handler是尔,在任何地方new Handler 都是什么線程下?
?ThreadLocal原理殉了,實(shí)現(xiàn)及如何保證Local屬性?
?請(qǐng)解釋下在單線程模型中Message拟枚、Handler薪铜、Message Queue众弓、Looper之間的關(guān)系
?請(qǐng)描述一下View事件傳遞分發(fā)機(jī)制
?Touch事件傳遞流程
?事件分發(fā)中的onTouch 和onTouchEvent 有什么區(qū)別,又該如何使用隔箍?
?View和ViewGroup分別有哪些事件分發(fā)相關(guān)的回調(diào)方法
?View刷新機(jī)制
?View繪制流程
?自定義控件原理
?自定義View如何提供獲取View屬性的接口田轧?
?Android代碼中實(shí)現(xiàn)WAP方式聯(lián)網(wǎng)
?AsyncTask機(jī)制
?AsyncTask原理及不足
?如何取消AsyncTask?
?為什么不能在子線程更新UI鞍恢?
?ANR產(chǎn)生的原因是什么傻粘?
?ANR定位和修正
?oom是什么?
?什么情況導(dǎo)致oom帮掉?
?有什么解決方法可以避免OOM弦悉?
?Oom 是否可以try catch?為什么蟆炊?
?內(nèi)存泄漏是什么稽莉?
?什么情況導(dǎo)致內(nèi)存泄漏?
?如何防止線程的內(nèi)存泄漏涩搓?
?內(nèi)存泄露場(chǎng)的解決方法
?內(nèi)存泄漏和內(nèi)存溢出區(qū)別污秆?
?LruCache默認(rèn)緩存大小
?ContentProvider的權(quán)限管理(解答:讀寫分離,權(quán)限控制-精確到表級(jí)昧甘,URL控制)
?如何通過(guò)廣播攔截和abort一條短信良拼?
?廣播是否可以請(qǐng)求網(wǎng)絡(luò)?
?廣播引起anr的時(shí)間限制是多少充边?
?計(jì)算一個(gè)view的嵌套層級(jí)
?Activity棧
?Android線程有沒(méi)有上限庸推?
?線程池有沒(méi)有上限?
?ListView重用的是什么浇冰?
?Android為什么引入Parcelable贬媒?
?有沒(méi)有嘗試簡(jiǎn)化Parcelable的使用?
(四)開發(fā)中常見(jiàn)的一些問(wèn)題
?ListView 中圖片錯(cuò)位的問(wèn)題是如何產(chǎn)生的?
?混合開發(fā)有了解嗎肘习?
?知道哪些混合開發(fā)的方式际乘?說(shuō)出它們的優(yōu)缺點(diǎn)和各自使用場(chǎng)景?(解答:比如:RN漂佩,weex脖含,H5,小程序仅仆,WPA等器赞。做Android的了解一些前端js等還是很有好處的)垢袱;
?屏幕適配的處理技巧都有哪些?
?服務(wù)器只提供數(shù)據(jù)接收接口墓拜,在多線程或多進(jìn)程條件下,如何保證數(shù)據(jù)的有序到達(dá)请契?
?動(dòng)態(tài)布局的理解
?怎么去除重復(fù)代碼咳榜?
?畫出 Android 的大體架構(gòu)圖
?Recycleview和ListView的區(qū)別
?ListView圖片加載錯(cuò)亂的原理和解決方案
?動(dòng)態(tài)權(quán)限適配方案夏醉,權(quán)限組的概念
?Android系統(tǒng)為什么會(huì)設(shè)計(jì)ContentProvider?
?下拉狀態(tài)欄是不是影響activity的生命周期
?如果在onStop的時(shí)候做了網(wǎng)絡(luò)請(qǐng)求涌韩,onResume的時(shí)候怎么恢復(fù)畔柔?
?Bitmap 使用時(shí)候注意什么?
?Bitmap的recycler()
?Android中開啟攝像頭的主要步驟
?ViewPager使用細(xì)節(jié)臣樱,如何設(shè)置成每次只初始化當(dāng)前的Fragment靶擦,其他的不初始化?
?點(diǎn)擊事件被攔截雇毫,但是想傳到下面的View玄捕,如何操作?
?微信主頁(yè)面的實(shí)現(xiàn)方式
?微信上消息小紅點(diǎn)的原理
?CAS介紹(這是阿里巴巴的面試題棚放,我不是很了解枚粘,可以參考博客: CAS簡(jiǎn)介)
三、混合開發(fā)面試題
大廠除了技術(shù)深度之外飘蚯,還要求你具備一些廣度的知識(shí)馍迄,比如你要會(huì)前端知識(shí),會(huì)混合開發(fā)局骤,至少會(huì)一種腳本語(yǔ)言攀圈,C c++更不用說(shuō)了,也是必會(huì)的峦甩。
?Hybrid做過(guò)嗎量承?
?Hybrid通信原理是什么,有做研究嗎穴店?
?react native有多少了解撕捍?講一下原理。
?weex了解嗎泣洞?如何自己實(shí)現(xiàn)類似技術(shù)忧风?
?flutter了解嗎??jī)?nèi)部是如何實(shí)現(xiàn)跨平臺(tái)的球凰?
?Dart語(yǔ)言有研究貴嗎狮腿?
?快應(yīng)用了解嗎?跟其她方式相比有什么優(yōu)缺點(diǎn)呕诉?
?說(shuō)說(shuō)你用過(guò)的混合開發(fā)技術(shù)有哪些缘厢?各有什么優(yōu)缺點(diǎn)?
?Python會(huì)嗎甩挫?
?會(huì)不會(huì)PHP贴硫?
?Gradle了解多少?groovy語(yǔ)法會(huì)嗎?
四英遭、高端技術(shù)面試題
這里講的是大公司需要用到的一些高端Android技術(shù)间护,這里專門整理了一個(gè)文檔,希望大家都可以看看挖诸。這些題目有點(diǎn)技術(shù)含量汁尺,需要好點(diǎn)時(shí)間去研究一下的。
(一)圖片
?圖片庫(kù)對(duì)比
?圖片庫(kù)的源碼分析
?圖片框架緩存實(shí)現(xiàn)
?LRUCache原理
?圖片加載原理
?自己去實(shí)現(xiàn)圖片庫(kù)多律,怎么做痴突?
?Glide源碼解析
?Glide使用什么緩存?
?Glide內(nèi)存緩存如何控制大欣擒瘛苞也?
(二)網(wǎng)絡(luò)和安全機(jī)制
?網(wǎng)絡(luò)框架對(duì)比和源碼分析
?自己去設(shè)計(jì)網(wǎng)絡(luò)請(qǐng)求框架,怎么做粘秆?
?okhttp源碼
?網(wǎng)絡(luò)請(qǐng)求緩存處理如迟,okhttp如何處理網(wǎng)絡(luò)緩存的
?從網(wǎng)絡(luò)加載一個(gè)10M的圖片,說(shuō)下注意事項(xiàng)
?TCP的3次握手和四次揮手
?TCP與UDP的區(qū)別
?TCP與UDP的應(yīng)用
?HTTP協(xié)議
?HTTP1.0與2.0的區(qū)別
?HTTP報(bào)文結(jié)構(gòu)
?HTTP與HTTPS的區(qū)別以及如何實(shí)現(xiàn)安全性
?如何驗(yàn)證證書的合法性?
?https中哪里用了對(duì)稱加密攻走,哪里用了非對(duì)稱加密殷勘,對(duì)加密算法(如RSA)等是否有了解?
?client如何確定自己發(fā)送的消息被server收到?
?談?wù)勀銓?duì)WebSocket的理解
?WebSocket與socket的區(qū)別
?談?wù)勀銓?duì)安卓簽名的理解。
?請(qǐng)解釋安卓為啥要加簽名機(jī)制?
?視頻加密傳輸
?App 是如何沙箱化昔搂,為什么要這么做玲销?
?權(quán)限管理系統(tǒng)(底層的權(quán)限是如何進(jìn)行 grant 的)?
(三)數(shù)據(jù)庫(kù)
?sqlite升級(jí)摘符,增加字段的語(yǔ)句
?數(shù)據(jù)庫(kù)框架對(duì)比和源碼分析
?數(shù)據(jù)庫(kù)的優(yōu)化
?數(shù)據(jù)庫(kù)數(shù)據(jù)遷移問(wèn)題
(四)算法
?排序算法有哪些贤斜?
?最快的排序算法是哪個(gè)?
?手寫一個(gè)冒泡排序
?手寫快速排序代碼
?快速排序的過(guò)程逛裤、時(shí)間復(fù)雜度瘩绒、空間復(fù)雜度
?手寫堆排序
?堆排序過(guò)程、時(shí)間復(fù)雜度及空間復(fù)雜度
?寫出你所知道的排序算法及時(shí)空復(fù)雜度带族,穩(wěn)定性
?二叉樹給出根節(jié)點(diǎn)和目標(biāo)節(jié)點(diǎn)锁荔,找出從根節(jié)點(diǎn)到目標(biāo)節(jié)點(diǎn)的路徑
?給阿里2萬(wàn)多名員工按年齡排序應(yīng)該選擇哪個(gè)算法?
?GC算法(各種算法的優(yōu)缺點(diǎn)以及應(yīng)用場(chǎng)景)
?蟻群算法與蒙特卡洛算法
?子串包含問(wèn)題(KMP 算法)寫代碼實(shí)現(xiàn)
?一個(gè)無(wú)序蝙砌,不重復(fù)數(shù)組阳堕,輸出N個(gè)元素,使得N個(gè)元素的和相加為M择克,給出時(shí)間復(fù)雜度恬总、空間復(fù)雜度。手寫算法
?萬(wàn)億級(jí)別的兩個(gè)URL文件A和B肚邢,如何求出A和B的差集C(提示:Bit映射->hash分組->多文件讀寫效率->磁盤尋址以及應(yīng)用層面對(duì)尋址的優(yōu)化)
?百度POI中如何試下查找最近的商家功能(提示:坐標(biāo)鏡像+R樹)壹堰。
?兩個(gè)不重復(fù)的數(shù)組集合中,求共同的元素。
?兩個(gè)不重復(fù)的數(shù)組集合中缀旁,這兩個(gè)集合都是海量數(shù)據(jù)记劈,內(nèi)存中放不下勺鸦,怎么求共同的元素并巍?
?一個(gè)文件中有100萬(wàn)個(gè)整數(shù),由空格分開换途,在程序中判斷用戶輸入的整數(shù)是否在此文件中懊渡。說(shuō)出最優(yōu)的方法
?一張Bitmap所占內(nèi)存以及內(nèi)存占用的計(jì)算
?2000萬(wàn)個(gè)整數(shù),找出第五十大的數(shù)字军拟?
?燒一根不均勻的繩剃执,從頭燒到尾總共需要1個(gè)小時(shí)。現(xiàn)在有若干條材質(zhì)相同的繩子懈息,問(wèn)如何用燒繩的方法來(lái)計(jì)時(shí)一個(gè)小時(shí)十五分鐘呢肾档?
?求1000以內(nèi)的水仙花數(shù)以及40億以內(nèi)的水仙花數(shù)
?5枚硬幣,2正3反如何劃分為兩堆然后通過(guò)翻轉(zhuǎn)讓兩堆中正面向上的硬8幣和反面向上的硬幣個(gè)數(shù)相同
?時(shí)針走一圈辫继,時(shí)針?lè)轴樦睾蠋状?br>
?N*N的方格紙,里面有多少個(gè)正方形
?x個(gè)蘋果怒见,一天只能吃一個(gè)、兩個(gè)姑宽、或者三個(gè)遣耍,問(wèn)多少天可以吃完?
(五)插件化炮车、模塊化舵变、組件化、熱修復(fù)瘦穆、增量更新纪隙、Gradle
?對(duì)熱修復(fù)和插件化的理解
?插件化原理分析
?模塊化實(shí)現(xiàn)(好處,原因)
?熱修復(fù),插件化
?項(xiàng)目組件化的理解
?描述清點(diǎn)擊 Android Studio 的 build 按鈕后發(fā)生了什么
(六)架構(gòu)設(shè)計(jì)和設(shè)計(jì)模式
?談?wù)勀銓?duì)Android設(shè)計(jì)模式的理解
?MVC MVP MVVM原理和區(qū)別
?你所知道的設(shè)計(jì)模式有哪些扛或?
?項(xiàng)目中常用的設(shè)計(jì)模式
?手寫生產(chǎn)者/消費(fèi)者模式
?寫出觀察者模式的代碼
?適配器模式瘫拣,裝飾者模式,外觀模式的異同告喊?
?用到的一些開源框架麸拄,介紹一個(gè)看過(guò)源碼的,內(nèi)部實(shí)現(xiàn)過(guò)程黔姜。
?談?wù)剬?duì)RxJava的理解
?RxJava的功能與原理實(shí)現(xiàn)
?RxJava的作用拢切,與平時(shí)使用的異步操作來(lái)比的優(yōu)缺點(diǎn)
?說(shuō)說(shuō)EventBus作用,實(shí)現(xiàn)方式秆吵,代替EventBus的方式
?從0設(shè)計(jì)一款A(yù)pp整體架構(gòu)淮椰,如何去做?
?說(shuō)一款你認(rèn)為當(dāng)前比較火的應(yīng)用并設(shè)計(jì)(比如:直播APP,P2P金融主穗,小視頻等)
?談?wù)剬?duì)java狀態(tài)機(jī)理解
?Fragment如果在Adapter中使用應(yīng)該如何解耦泻拦?
?Binder機(jī)制及底層實(shí)現(xiàn)
?對(duì)于應(yīng)用更新這塊是如何做的?(解答:灰度忽媒,強(qiáng)制更新争拐,分區(qū)域更新)?
?實(shí)現(xiàn)一個(gè)Json解析器(可以通過(guò)正則提高速度)
?統(tǒng)計(jì)啟動(dòng)時(shí)長(zhǎng),標(biāo)準(zhǔn)
(七)性能優(yōu)化
?如何對(duì)Android 應(yīng)用進(jìn)行性能分析以及優(yōu)化?
?ddms 和 traceView
?性能優(yōu)化如何分析systrace晦雨?
?用IDE如何分析內(nèi)存泄漏架曹?
?Java多線程引發(fā)的性能問(wèn)題,怎么解決闹瞧?
?啟動(dòng)頁(yè)白屏及黑屏解決绑雄?
?啟動(dòng)太慢怎么解決?
?怎么保證應(yīng)用啟動(dòng)不卡頓奥邮?
?App啟動(dòng)崩潰異常捕捉
?自定義View注意事項(xiàng)
?現(xiàn)在下載速度很慢,試從網(wǎng)絡(luò)協(xié)議的角度分析原因,并優(yōu)化(提示:網(wǎng)絡(luò)的5層都可以涉及)万牺。
?Https請(qǐng)求慢的解決辦法(提示:DNS,攜帶數(shù)據(jù)洽腺,直接訪問(wèn)IP)
?如何保持應(yīng)用的穩(wěn)定性
?RecyclerView和ListView的性能對(duì)比
?ListView的優(yōu)化
?RecycleView優(yōu)化
?View渲染
?Bitmap如何處理大圖脚粟,如一張30M的大圖,如何預(yù)防OOM
?java中的四種引用的區(qū)別以及使用場(chǎng)景
?強(qiáng)引用置為null已脓,會(huì)不會(huì)被回收珊楼?
(八)NDK、jni度液、Binder厕宗、AIDL、進(jìn)程通信有關(guān)
?請(qǐng)介紹一下NDK
?什么是NDK庫(kù)?
?jni用過(guò)嗎堕担?
?如何在jni中注冊(cè)native函數(shù)已慢,有幾種注冊(cè)方式?
?Java如何調(diào)用c、c++語(yǔ)言霹购?
?jni如何調(diào)用java層代碼佑惠?
?進(jìn)程間通信的方式?
?Binder機(jī)制
?簡(jiǎn)述IPC齐疙?
?什么是AIDL膜楷?
?AIDL解決了什么問(wèn)題?
?AIDL如何使用贞奋?
?Android 上的 Inter-Process-Communication 跨進(jìn)程通信時(shí)如何工作的赌厅?
?多進(jìn)程場(chǎng)景遇見(jiàn)過(guò)么?
?Android進(jìn)程分類轿塔?
?進(jìn)程和 Application 的生命周期特愿?
?進(jìn)程調(diào)度
?談?wù)剬?duì)進(jìn)程共享和線程安全的認(rèn)識(shí)
?談?wù)剬?duì)多進(jìn)程開發(fā)的理解以及多進(jìn)程應(yīng)用場(chǎng)景
?什么是協(xié)程仲墨?
(九)framework層、ROM定制揍障、Ubuntu目养、Linux之類的問(wèn)題
?java虛擬機(jī)的特性
?談?wù)剬?duì)jvm的理解
?JVM內(nèi)存區(qū)域,開線程影響哪塊內(nèi)存
?對(duì)Dalvik毒嫡、ART虛擬機(jī)有什么了解癌蚁?
?Art和Dalvik對(duì)比
?虛擬機(jī)原理,如何自己設(shè)計(jì)一個(gè)虛擬機(jī)(內(nèi)存管理审胚,類加載匈勋,雙親委派)
?談?wù)勀銓?duì)雙親委派模型理解
?JVM內(nèi)存模型礼旅,內(nèi)存區(qū)域
?類加載機(jī)制
?談?wù)剬?duì)ClassLoader(類加載器)的理解
?談?wù)剬?duì)動(dòng)態(tài)加載(OSGI)的理解
?內(nèi)存對(duì)象的循環(huán)引用及避免
?內(nèi)存回收機(jī)制膳叨、GC回收策略、GC原理時(shí)機(jī)以及GC對(duì)象
?垃圾回收機(jī)制與調(diào)用System.gc()區(qū)別
?Ubuntu編譯安卓系統(tǒng)
?系統(tǒng)啟動(dòng)流程是什么痘系?(提示:Zygote進(jìn)程 –> SystemServer進(jìn)程 –> 各種系統(tǒng)服務(wù) –> 應(yīng)用進(jìn)程)
?大體說(shuō)清一個(gè)應(yīng)用程序安裝到手機(jī)上時(shí)發(fā)生了什么
?簡(jiǎn)述Activity啟動(dòng)全部過(guò)程
?App啟動(dòng)流程菲嘴,從點(diǎn)擊桌面開始
?邏輯地址與物理地址,為什么使用邏輯地址汰翠?
?Android為每個(gè)應(yīng)用程序分配的內(nèi)存大小是多少龄坪?
?Android中進(jìn)程內(nèi)存的分配,能不能自己分配定額內(nèi)存复唤?
?進(jìn)程苯√铮活的方式
?如何保證一個(gè)后臺(tái)服務(wù)不被殺死?(相同問(wèn)題:如何保證service在后臺(tái)不被kill佛纫?)比較省電的方式是什么妓局?
?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)題
?介紹你做過(guò)的哪些項(xiàng)目
?都使用過(guò)哪些框架蜈漓、平臺(tái)穆桂?
?都使用過(guò)哪些自定義控件?
?研究比較深入的領(lǐng)域有哪些融虽?
?對(duì)業(yè)內(nèi)信息的關(guān)注渠道有哪些享完?
?最近都讀哪些書?
?有沒(méi)有什么開源項(xiàng)目衣形?
?自己最擅長(zhǎng)的技術(shù)點(diǎn)驼侠,最感興趣的技術(shù)領(lǐng)域和技術(shù)點(diǎn)
?項(xiàng)目中用了哪些開源庫(kù)姿鸿,如何避免因?yàn)橐腴_源庫(kù)而導(dǎo)致的安全性和穩(wěn)定性問(wèn)題
?實(shí)習(xí)過(guò)程中做了什么,有什么產(chǎn)出倒源?
(二)HR提出的面試問(wèn)題
?您在前一家公司的離職原因是什么苛预?
?講一件你印象最深的一件事情
?介紹一個(gè)你影響最深的項(xiàng)目
?介紹你最熱愛(ài)最擅長(zhǎng)的專業(yè)領(lǐng)域
?公司實(shí)習(xí)最大的收獲是什么?
?與上級(jí)意見(jiàn)不一致時(shí)笋熬,你將怎么辦热某?
?自己的優(yōu)點(diǎn)和缺點(diǎn)是什么?并舉例說(shuō)明胳螟?
?你的學(xué)習(xí)方法是什么樣的昔馋?實(shí)習(xí)過(guò)程中如何學(xué)習(xí)?實(shí)習(xí)項(xiàng)目中遇到的最大困難是什么以及如何解決的糖耸?
?說(shuō)一件最能證明你能力的事情
?針對(duì)你你申請(qǐng)的這個(gè)職位秘遏,你認(rèn)為你還欠缺什么
?如果通過(guò)這次面試我們單位錄用了你,但工作一段時(shí)間卻發(fā)現(xiàn)你根本不適合這個(gè)職位嘉竟,你怎么辦邦危?
?項(xiàng)目中遇到最大的困難是什么?如何解決的舍扰?
?你的職業(yè)規(guī)劃以及個(gè)人目標(biāo)倦蚪、未來(lái)發(fā)展路線及求職定位
?如果你在這次面試中沒(méi)有被錄用,你怎么打算边苹?
?評(píng)價(jià)下自己陵且,評(píng)價(jià)下自己的技術(shù)水平,個(gè)人代碼量如何个束?
?通過(guò)哪些渠道了解的招聘信息慕购,其他同學(xué)都投了哪些公司?
?業(yè)余都有哪些愛(ài)好播急?
?你做過(guò)的哪件事最令自己感到驕傲脓钾?
?假如你晚上要去送一個(gè)出國(guó)的同學(xué)去機(jī)場(chǎng),可單位臨時(shí)有事非你辦不可桩警,你怎么辦可训?
?就你申請(qǐng)的這個(gè)職位,你認(rèn)為你還欠缺什么捶枢?
?當(dāng)前的offer狀況握截;如果BATH都給了offer該如何選?
?你對(duì)一份工作更看重哪些方面烂叔?平臺(tái)谨胞,技術(shù),氛圍蒜鸡,城市胯努,還是money牢裳?
?理想薪資范圍;杭州崗和北京崗選哪個(gè)叶沛?
?理想中的工作環(huán)境是什么蒲讯?
?談?wù)勀銓?duì)跳槽的看法
?說(shuō)說(shuō)你對(duì)行業(yè)、技術(shù)發(fā)展趨勢(shì)的看法
?實(shí)習(xí)過(guò)程中周圍同事/同學(xué)有哪些值得學(xué)習(xí)的地方灰署?
?家人對(duì)你的工作期望及自己的工作期望
?如果你的工作出現(xiàn)失誤判帮,給本公司造成經(jīng)濟(jì)損失,你認(rèn)為該怎么辦溉箕?
?若上司在公開會(huì)議上誤會(huì)你了晦墙,該如何解決?
?是否可以實(shí)習(xí)肴茄,可以實(shí)習(xí)多久晌畅?
?在五年的時(shí)間內(nèi),你的職業(yè)規(guī)劃
大廠面試題加Android高級(jí)進(jìn)階資料和視屏想要進(jìn)階的可以獲取哦独郎。