溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

Android面試中重要的面試題有哪些

發(fā)布時間:2022-01-12 11:07:24 來源:億速云 閱讀:139 作者:iii 欄目:移動開發(fā)

今天小編給大家分享一下Android面試中重要的面試題有哪些的相關知識點,內(nèi)容詳細,邏輯清晰,相信大部分人都還太了解這方面的知識,所以分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后有所收獲,下面我們一起來了解一下吧。

說一下java多態(tài)的理解,以及接繼承,和接口的理解

對于多態(tài)的定義
不同類的對象對統(tǒng)一函數(shù)做出不同對的響應或者動作。
作用
主要是消除類之間的耦合性,靈活性比較強,利于代碼的編寫和修改。尤其在處理大量的運算和操作時,可以靈活地簡化,替換或者是修改代碼!

三個必要條件
1、一個凳子(繼承extends)
2、重寫
3、父類引用指向子類對象

for example

Android面試中重要的面試題有哪些

Android面試中重要的面試題有哪些

Android面試中重要的面試題有哪些

Android面試中重要的面試題有哪些

Android面試中重要的面試題有哪些

Android面試中重要的面試題有哪些

**測試結(jié)果:

Android面試中重要的面試題有哪些

oKhttp的 原理

1.同步和異步:

  • 1.異步使用了Dispatcher來將存儲在 Deque 中的請求分派給線程池中各個線程執(zhí)行。

  • 2.當任務執(zhí)行完成后,無論是否有異常,finally代碼段總會被執(zhí)行,也就是會調(diào)用Dispatcher的finished函數(shù),它將正在運行的任務Call從隊列runningAsyncCalls中移除后,主動的把緩存隊列向前走了一步。

2.連接池:

  • 1.一個Connection封裝了一個socket,ConnectionPool中儲存s著所有的Connection,StreamAllocation是引用計數(shù)的一個單位

  • 2.當一個請求獲取一個Connection的時候要傳入一個StreamAllocation,Connection中存著一個弱引用的StreamAllocation列表,每當上層應用引用一次Connection,StreamAllocation就會加一個。反之如果上層應用不使用了,就會刪除一個。

  • 3.ConnectionPool中會有一個后臺任務定時清理StreamAllocation列表為空的Connection。5分鐘時間,維持5個socket

3.選擇路線與建立連接

  • 1.選擇路線有兩種方式:

  • 3.代理好處:HTTP代理會幫你在遠程服務器進行DNS查詢,可以減少DNS劫持。

  • 1.無代理,那么在本地使用DNS查找到ip,注意結(jié)果是數(shù)組,即一個域名有多個IP,這就是自動重連的來源

  • 2.有代理HTTP:設置socket的ip為代理地址的ip,設置socket的端口為代理地址的端口

  • 2.建立連接

  • 1.連接池中已經(jīng)存在連接,就從中取出(get)RealConnection,如果沒有命中就進入下一步

  • 2.根據(jù)選擇的路線(Route),調(diào)用Platform.get().connectSocket選擇當前平臺Runtime下最好的socket庫進行握手

  • 3.將建立成功的RealConnection放入(put)連接池緩存

  • 4.如果存在TLS,就根據(jù)SSL版本與證書進行安全握手

  • 5.構造HttpStream并維護剛剛的socket連接,管道建立完成

4.職責鏈模式:緩存、重試、建立連接等功能存在于攔截器中網(wǎng)絡請求相關,主要是網(wǎng)絡請求優(yōu)化。網(wǎng)絡請求的時候遇到的問題

線程同步的問題,常用的線程同步

1.sycn:保證了原子性、可見性、有序性
2.鎖:保證了原子性、可見性、有序性

  • 1.自旋鎖:可以使線程在沒有取得鎖的時候,不被掛起,而轉(zhuǎn)去執(zhí)行一個空循環(huán)。

  • 1.優(yōu)點:線程被掛起的幾率減少,線程執(zhí)行的連貫性加強。用于對于鎖競爭不是很激烈,鎖占用時間很短的并發(fā)線程。

  • 2.缺點:過多浪費CPU時間,有一個線程連續(xù)兩次試圖獲得自旋鎖引起死鎖

  • 2.阻塞鎖:沒得到鎖的線程等待或者掛起,Sycn、Lock

  • 3.可重入鎖:一個線程可多次獲取該鎖,Sycn、Lock

  • 4.悲觀鎖:每次去拿數(shù)據(jù)的時候都認為別人會修改,所以會阻塞全部其他線程 Sycn、Lock

  • 5.樂觀鎖:每次去拿數(shù)據(jù)的時候都認為別人不會修改,所以不會上鎖,但是在更新的時候會判斷一下在此期間別人有沒有去更新這個數(shù)據(jù),可以使用版本號等機制。cas

  • 6.顯示鎖和內(nèi)置鎖:顯示鎖用Lock來定義、內(nèi)置鎖用synchronized。

  • 7.讀-寫鎖:為了提高性能,Java提供了讀

3.volatile

  • 1.只能保證可見性,不能保證原子性

  • 2.自增操作有三步,此時多線程寫會出現(xiàn)問題

4.cas

  • 1.操作:內(nèi)存值V、舊的預期值A、要修改的值B,當且僅當預期值A和內(nèi)存值V相同時,將內(nèi)存值修改為B并返回true,否則什么都不做并返回false。

  • 2.解釋:本地副本為A,共享內(nèi)存為V,線程A要把V修改成B。某個時刻線程A要把V修改成B,如果A和V不同那么就表示有其他線程在修改V,此時就表示修改失敗,否則表示沒有其他線程修改,那么把V改成B。

  • 3.局限:如果V被修改成V1然后又被改成V,此時cas識別不出變化,還是認為沒有其他線程在修改V,此時就會有問題

  • 4.局限解決:將V帶上版本。

5.線程不安全到底是怎么回事:

  • 1.一個線程寫,多個線程讀的時候,會造成寫了一半就去讀

  • 2.多線程寫,會造成臟數(shù)據(jù)

    Asynctask和線程池,GC相關(怎么判斷哪些內(nèi)存該GC,GC算法)

1.Asynctask:異步任務類,單線程線程池+Handler
2.線程池:

  • 1.ThreadPoolExecutor:通過Executors可以構造單線程池、固定數(shù)目線程池、不固定數(shù)目線程池。

  • 2.ScheduledThreadPoolExecutor:可以延時調(diào)用線程或者延時重復調(diào)度線程。 3.GC相關:重要

  • 1.搜索算法: 1.引用計數(shù)
    2.圖搜索,可達性分析

  • 2.回收算法: 1.標記清除復制:用于青年代
    2.標記整理:用于老年代

  • 3.堆分區(qū): 1.青年區(qū)eden 80%、survivor1 10%、survivor2 10%
    2.老年區(qū)

  • 4.虛擬機棧分區(qū):
    1.局部變量表
    2.操作數(shù)棧
    3.動態(tài)鏈接
    4.方法返回地址

  • 5.GC Roots:
    1.虛擬機棧(棧楨中的本地變量表)中的引用的對象
    2.方法區(qū)中的類靜態(tài)屬性引用的對象
    3.方法區(qū)中的常量引用的對象
    4.本地方法棧中JNI的引用的對象

java類加載過程:
  • 1.加載時機:創(chuàng)建實例、訪問靜態(tài)變量或方法、反射、加載子類之前

  • 2.驗證:驗證文件格式、元數(shù)據(jù)、字節(jié)碼、符號引用的正確性

  • 3.加載:根據(jù)全類名獲取文件字節(jié)流、將字節(jié)流轉(zhuǎn)化為靜態(tài)儲存結(jié)構放入方法區(qū)、生成class對象

  • 4.準備:在堆上為靜態(tài)變量劃分內(nèi)存

  • 5.解析:將常量池中的符號引用轉(zhuǎn)換為直接引用

  • 6.初始化:初始化靜態(tài)變量

mvc、mvp、mvvm:
  • 1.mvc:數(shù)據(jù)、View、Activity,View將操作反饋給Activity,Activitiy去獲取數(shù)據(jù),數(shù)據(jù)通過觀察者模式刷新給View。循環(huán)依賴

  • 1.Activity重,很難單元測試

  • 2.View和Model耦合嚴重

  • 2.mvp:數(shù)據(jù)、View、Presenter,View將操作給Presenter,Presenter去獲取數(shù)據(jù),數(shù)據(jù)獲取好了返回給Presenter,Presenter去刷新View。PV,PM雙向依賴

  • 1.接口爆炸

  • 2.Presenter很重

  • 3.mvvm:數(shù)據(jù)、View、ViewModel,View將操作給ViewModel,ViewModel去獲取數(shù)據(jù),數(shù)據(jù)和界面綁定了,數(shù)據(jù)更新界面更新。

  • 1.viewModel的業(yè)務邏輯可以單獨拿來測試

  • 2.一個view 對應一個 viewModel 業(yè)務邏輯可以分離,不會出現(xiàn)全能類

  • 3.數(shù)據(jù)和界面綁定了,不用寫垃圾代碼,但是復用起來不舒服

ANR的形成,各個組件上出現(xiàn)ARN的時間限制是多少

1.只要是主線程耗時的操作就會ARN 如io
2.broadcast超時時間為10秒 按鍵無響應的超時時間為5秒 前臺service無響應的超時時間為20秒,后臺service為200秒

Serializable和Parcelable 的區(qū)別

1.P 消耗內(nèi)存小
2.網(wǎng)絡傳輸用S 程序內(nèi)使用P
3.S將數(shù)據(jù)持久化方便
4.S使用了反射 容易觸發(fā)垃圾回收 比較慢

Sharedpreferences源碼簡述

1.儲存于硬盤上的xml鍵值對,數(shù)據(jù)多了會有性能問題
2.ContextImpl記錄著SharedPreferences的重要數(shù)據(jù),文件路徑和實例的鍵值對
3.在xml文件全部內(nèi)加載到內(nèi)存中之前,讀取操作是阻塞的,在xml文件全部內(nèi)加載到內(nèi)存中之后,是直接讀取內(nèi)存中的數(shù)據(jù)
4.apply因為是異步的沒有返回值, commit是同步的有返回值能知道修改是否提交成功
5.多并發(fā)的提交commit時,需等待正在處理的commit數(shù)據(jù)更新到磁盤文件后才會繼續(xù)往下執(zhí)行,從而降低效率; 而apply只是原子更新到內(nèi)存,后調(diào)用apply函數(shù)會直接覆蓋前面內(nèi)存數(shù)據(jù),從一定程度上提高很多效率。 3.edit()每次都是創(chuàng)建新的EditorImpl對象.

ANR的形成,各個組件上出現(xiàn)ARN的時間限制是多少

1.只要是主線程耗時的操作就會ARN 如io
2.broadcast超時時間為10秒 按鍵無響應的超時時間為5秒 前臺service無響應的超時時間為20秒,后臺service為200秒

apk瘦身:

1.classes.dex:通過代碼混淆,刪掉不必要的jar包和代碼實現(xiàn)該文件的優(yōu)化
2.資源文件:通過Lint工具掃描代碼中沒有使用到的靜態(tài)資源
3.圖片資源:使用tinypng和webP,下面詳細介紹圖片資源優(yōu)化的方案,矢量圖
4.SO文件將不用的去掉,目前主流app一般只放一個arm的so包

以上就是“Android面試中重要的面試題有哪些”這篇文章的所有內(nèi)容,感謝各位的閱讀!相信大家閱讀完這篇文章都有很大的收獲,小編每天都會為大家更新不同的知識,如果還想學習更多的知識,請關注億速云行業(yè)資訊頻道。

向AI問一下細節(jié)

免責聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權內(nèi)容。

AI