Android 面試經(jīng)驗(yàn)

1.JAVA 基礎(chǔ)問題

你對線程的認(rèn)識?

你對進(jìn)程的認(rèn)識?

你對面向?qū)ο蟮恼J(rèn)識?

wait 和 sleep的區(qū)別?

權(quán)限修飾符有哪些?private protected default public

3.Android UI加載慢 界面卡頓原因?

Android 界面繪制過程中有耗時(shí)操作,解決辦法:將耗時(shí)操作放到子線程中,更新UI在

4.Android 內(nèi)存泄露的原因以及解決方案?

5.listview 實(shí)現(xiàn)瀑布流?

http://blog.csdn.net/guolin_blog/article/details/46361889

6.界面 瀑布流實(shí)現(xiàn)?

7.Android程序的熱更新?

http://mp.weixin.qq.com/s?__biz=MzI0MjE3OTYwMg==&mid=2649548089&idx=1&sn=939f45217087f332f945a703c658bbe1&chksm=f1180e44c66f8752b54ff55e2f8994eec97fcca8e30c9f5a10e3503dcc029483fd630d22dd4e&scene=21#wechat_redirect

主流兩種方式:1.通過ClassLoader 替換類 需要重啟應(yīng)用

2.底層方法指向替換方法? 無需重啟應(yīng)用

8.內(nèi)存泄露和內(nèi)存溢出

內(nèi)存溢出 out of memory,是指程序在申請內(nèi)存時(shí),沒有足夠的內(nèi)存空間供其使用,出現(xiàn)out of memory

內(nèi)存泄露 memory leak,是指程序在申請內(nèi)存后,無法釋放已申請的內(nèi)存空間,一次內(nèi)存泄露危害可以忽略,但內(nèi)存泄露堆積后果很嚴(yán)重,無論多少內(nèi)存,遲早會(huì)被占光。

常見的內(nèi)存泄漏

1.較大的資源對象沒有釋放 File 沒有close ,cursor 沒有關(guān)閉,Bitmap沒有回收

2.Android 中注冊沒有取消注冊

3.內(nèi)部類 持有外部類的引用造成的? 常見handler

9.fragment 生命周期

http://blog.csdn.net/forever_crying/article/details/8238863/

10.android ANR的原因以及解決辦法

http://www.itdecent.cn/p/7fd95bc2a55c

11.android view touch 事件傳遞

ViewGroup在接受到上級傳下來的事件時(shí),如果是一系列Touch事件的開始(ACTION_DOWN),ViewGroup會(huì)先看看自己需不需要攔截這個(gè)事件(onInterceptTouchEvent,ViewGroup的默認(rèn)實(shí)現(xiàn)直接返回false表示不攔截),接著ViewGroup遍歷自己所有的View。找到當(dāng)前點(diǎn)擊的那個(gè)View,馬上調(diào)用目標(biāo)View的dispatchTouchEvent。如果目標(biāo)View的dispatchTouchEvent返回false,那么認(rèn)為目標(biāo)View只是在那個(gè)位置而已,它并不想接受這個(gè)事件,只想安安靜靜的做一個(gè)View(我靜靜地看著你們裝*)。此時(shí),ViewGroup還會(huì)去走一下自己dispatchTouchEvent,Done!

12.volatile與synchronized

1)volatile本質(zhì)是在告訴jvm當(dāng)前變量在寄存器中的值是不確定的,需要從主存中讀取,synchronized則是鎖定當(dāng)前變量,只有當(dāng)前線程可以訪問該變量,其他線程被阻塞住.2)volatile僅能使用在變量級別,synchronized則可以使用在變量,方法.3)volatile僅能實(shí)現(xiàn)變量的修改可見性,而synchronized則可以保證變量的修改可見性和原子性.

《Java編程思想》上說,定義long或double變量時(shí),如果使用volatile關(guān)鍵字,就會(huì)獲得(簡單的賦值與返回操作)原子性4)volatile不會(huì)造成線程的阻塞,而synchronized可能會(huì)造成線程的阻塞.

13.通過listview 實(shí)現(xiàn)瀑布流

http://www.2cto.com/kf/201510/444916.html

14.Android 中常用的設(shè)計(jì)模式

1.單例設(shè)計(jì)模式

2.生產(chǎn)者消費(fèi)者模式

3.觀察者模式

4.工廠設(shè)計(jì)模式

15.數(shù)據(jù)結(jié)構(gòu)和算法問題

16.Android 的消息處理原理

handler message Looper

17.Android 的Binder 機(jī)制

18.Android中JNI的使用

19.Android App中常用的bug 定位和性能調(diào)優(yōu)工具

18.版本管理工具 Git 和SVN

Git:?http://www.bootcss.com/p/git-guide/

19.android 的垃圾回收機(jī)制

20.activity LaunchMode Task Flag 完整的流程

21.View 的繪制 Touch事件的分發(fā) 從WindowsManagerService 完成的流程

22.Wait 和 sleep的區(qū)別

23.?HTTPS和HTTP的區(qū)別主要如下:

1、https協(xié)議需要到ca申請證書,一般免費(fèi)證書較少,因而需要一定費(fèi)用。

2、http是超文本傳輸協(xié)議,信息是明文傳輸,https則是具有安全性的ssl加密傳輸協(xié)議。

3、http和https使用的是完全不同的連接方式,用的端口也不一樣,前者是80,后者是443。

4、http的連接很簡單,是無狀態(tài)的;HTTPS協(xié)議是由SSL+HTTP協(xié)議構(gòu)建的可進(jìn)行加密傳輸、身份認(rèn)證的網(wǎng)絡(luò)協(xié)議,比http協(xié)議安 ? ? ? ? ? ? 全。

24.https 證書校驗(yàn)原理/https 交互流程

客戶端在使用HTTPS方式與Web服務(wù)器通信時(shí)有以下幾個(gè)步驟,如圖所示。

(1)客戶使用https的URL訪問Web服務(wù)器,要求與Web服務(wù)器建立SSL連接。

(2)Web服務(wù)器收到客戶端請求后,會(huì)將網(wǎng)站的證書信息(證書中包含公鑰)傳送一份給客戶端。

(3)客戶端的瀏覽器與Web服務(wù)器開始協(xié)商SSL連接的安全等級,也就是信息加密的等級。

(4)客戶端的瀏覽器根據(jù)雙方同意的安全等級,建立會(huì)話密鑰,然后利用網(wǎng)站的公鑰將會(huì)話密鑰加密,并傳送給網(wǎng)站。

(5)Web服務(wù)器利用自己的私鑰解密出會(huì)話密鑰。

(6)Web服務(wù)器利用會(huì)話密鑰加密與客戶端之間的通信。

1.為什么從上家公司離職?

答:公司目前情況估計(jì)您也了解,有的同事社保和公積金被

2.談一下你最近做的項(xiàng)目?

視頻通話項(xiàng)目 ?IMSDK項(xiàng)目 PushSDK項(xiàng)目

設(shè)計(jì)技術(shù):信令設(shè)計(jì) websocket長連接 斷線重連 雙向心跳 智能心跳

開發(fā)中遇到哪些問題? 如何解決的?

LeakCanary 解決內(nèi)存泄漏問題

雙向心跳 智能心跳 客戶端狀態(tài)機(jī)

3.Android UI加載慢 界面卡頓原因?

4.Android 內(nèi)存泄露的原因以及解決方案?

5.listview 實(shí)現(xiàn)瀑布流?

http://blog.csdn.net/guolin_blog/article/details/46361889

6.界面 瀑布流實(shí)現(xiàn)?

7.Android程序的熱更新?

http://mp.weixin.qq.com/s?__biz=MzI0MjE3OTYwMg==&mid=2649548089&idx=1&sn=939f45217087f332f945a703c658bbe1&chksm=f1180e44c66f8752b54ff55e2f8994eec97fcca8e30c9f5a10e3503dcc029483fd630d22dd4e&scene=21#wechat_redirect

8.內(nèi)存泄露和內(nèi)存溢出

9.fragment 生命周期

http://blog.csdn.net/forever_crying/article/details/8238863/

10.android ANR的原因以及解決辦法

http://www.itdecent.cn/p/7fd95bc2a55c

11.android view touch 事件傳遞

ViewGroup在接受到上級傳下來的事件時(shí),如果是一系列Touch事件的開始(ACTION_DOWN),ViewGroup會(huì)先看看自己需不需要攔截這個(gè)事件(onInterceptTouchEvent,ViewGroup的默認(rèn)實(shí)現(xiàn)直接返回false表示不攔截),接著ViewGroup遍歷自己所有的View。找到當(dāng)前點(diǎn)擊的那個(gè)View,馬上調(diào)用目標(biāo)View的dispatchTouchEvent。如果目標(biāo)View的dispatchTouchEvent返回false,那么認(rèn)為目標(biāo)View只是在那個(gè)位置而已,它并不想接受這個(gè)事件,只想安安靜靜的做一個(gè)View(我靜靜地看著你們裝*)。此時(shí),ViewGroup還會(huì)去走一下自己dispatchTouchEvent,Done!

12.volatile與synchronized

1)volatile本質(zhì)是在告訴jvm當(dāng)前變量在寄存器中的值是不確定的,需要從主存中讀取,synchronized則是鎖定當(dāng)前變量,只有當(dāng)前線程可以訪問該變量,其他線程被阻塞住.2)volatile僅能使用在變量級別,synchronized則可以使用在變量,方法.3)volatile僅能實(shí)現(xiàn)變量的修改可見性,而synchronized則可以保證變量的修改可見性和原子性.

《Java編程思想》上說,定義long或double變量時(shí),如果使用volatile關(guān)鍵字,就會(huì)獲得(簡單的賦值與返回操作)原子性4)volatile不會(huì)造成線程的阻塞,而synchronized可能會(huì)造成線程的阻塞.

13.通過listview 實(shí)現(xiàn)瀑布流

http://www.2cto.com/kf/201510/444916.html

14.Android 中常用的設(shè)計(jì)模式

1.單例設(shè)計(jì)模式

2.生產(chǎn)者消費(fèi)者模式

3.觀察者模式

4.工廠設(shè)計(jì)模式

15.數(shù)據(jù)結(jié)構(gòu)和算法問題

16.Android 的消息處理原理

handler message Looper

17.Android 的Binder 機(jī)制

18.Android中JNI的使用

19.Android App中常用的bug 定位和性能調(diào)優(yōu)工具

18.版本管理工具 Git 和SVN

Git:?http://www.bootcss.com/p/git-guide/

19.android 的垃圾回收機(jī)制

20.activity LaunchMode Task Flag 完整的流程

21.View 的繪制 Touch事件的分發(fā) 從WindowsManagerService 完成的流程

22.Wait 和 sleep的區(qū)別

23.?HTTPS和HTTP的區(qū)別主要如下:

1、https協(xié)議需要到ca申請證書,一般免費(fèi)證書較少,因而需要一定費(fèi)用。

2、http是超文本傳輸協(xié)議,信息是明文傳輸,https則是具有安全性的ssl加密傳輸協(xié)議。

3、http和https使用的是完全不同的連接方式,用的端口也不一樣,前者是80,后者是443。

4、http的連接很簡單,是無狀態(tài)的;HTTPS協(xié)議是由SSL+HTTP協(xié)議構(gòu)建的可進(jìn)行加密傳輸、身份認(rèn)證的網(wǎng)絡(luò)協(xié)議,比http協(xié)議安 ? ? ? ? ? ? 全。

24.https 證書校驗(yàn)原理/https 交互流程

客戶端在使用HTTPS方式與Web服務(wù)器通信時(shí)有以下幾個(gè)步驟,如圖所示。

(1)客戶使用https的URL訪問Web服務(wù)器,要求與Web服務(wù)器建立SSL連接。

(2)Web服務(wù)器收到客戶端請求后,會(huì)將網(wǎng)站的證書信息(證書中包含公鑰)傳送一份給客戶端。

(3)客戶端的瀏覽器與Web服務(wù)器開始協(xié)商SSL連接的安全等級,也就是信息加密的等級。

(4)客戶端的瀏覽器根據(jù)雙方同意的安全等級,建立會(huì)話密鑰,然后利用網(wǎng)站的公鑰將會(huì)話密鑰加密,并傳送給網(wǎng)站。

(5)Web服務(wù)器利用自己的私鑰解密出會(huì)話密鑰。

(6)Web服務(wù)器利用會(huì)話密鑰加密與客戶端之間的通信。

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

相關(guān)閱讀更多精彩內(nèi)容

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