摘要:優(yōu)點線程被掛起的幾率減少,線程執(zhí)行的連貫性加強(qiáng)。用于對于鎖競爭不是很激烈,鎖占用時間很短的并發(fā)線程。解釋本地副本為,共享內(nèi)存為,線程要把修改成。
#### 說一下java多態(tài)的理解,以及接繼承,和接口的理解
于哥在這里只講多態(tài),其他自己上網(wǎng)體會
對于多態(tài)的定義
不同類的對象對統(tǒng)一函數(shù)做出不同對的響應(yīng)或者動作。
作用
主要是消除類之間的耦合性,靈活性比較強(qiáng),利于代碼的編寫和修改。尤其在處理大量的運(yùn)算和操作時,可以靈活地簡化,替換或者是修改代碼!
三個必要條件
1、一個凳子(繼承extends)
2、重寫
3、父類引用指向子類對象
for example
測試結(jié)果:
1.同步和異步:
1.異步使用了Dispatcher來將存儲在 Deque 中的請求分派給線程池中各個線程執(zhí)行。
2.當(dāng)任務(wù)執(zhí)行完成后,無論是否有異常,finally代碼段總會被執(zhí)行,也就是會調(diào)用Dispatcher的finished函數(shù),它將正在運(yùn)行的任務(wù)Call從隊列runningAsyncCalls中移除后,主動的把緩存隊列向前走了一步。
2.連接池:
1.一個Connection封裝了一個socket,ConnectionPool中儲存s著所有的Connection,StreamAllocation是引用計數(shù)的一個單位
2.當(dāng)一個請求獲取一個Connection的時候要傳入一個StreamAllocation,Connection中存著一個弱引用的StreamAllocation列表,每當(dāng)上層應(yīng)用引用一次Connection,StreamAllocation就會加一個。反之如果上層應(yīng)用不使用了,就會刪除一個。
3.ConnectionPool中會有一個后臺任務(wù)定時清理StreamAllocation列表為空的Connection。5分鐘時間,維持5個socket
3.選擇路線與建立連接
1.選擇路線有兩種方式:
1.無代理,那么在本地使用DNS查找到ip,注意結(jié)果是數(shù)組,即一個域名有多個IP,這就是自動重連的來源
2.有代理HTTP:設(shè)置socket的ip為代理地址的ip,設(shè)置socket的端口為代理地址的端口
3.代理好處:HTTP代理會幫你在遠(yuǎn)程服務(wù)器進(jìn)行DNS查詢,可以減少DNS劫持。
2.建立連接
1.連接池中已經(jīng)存在連接,就從中取出(get)RealConnection,如果沒有命中就進(jìn)入下一步
2.根據(jù)選擇的路線(Route),調(diào)用Platform.get().connectSocket選擇當(dāng)前平臺Runtime下最好的socket庫進(jìn)行握手
3.將建立成功的RealConnection放入(put)連接池緩存
4.如果存在TLS,就根據(jù)SSL版本與證書進(jìn)行安全握手
5.構(gòu)造HttpStream并維護(hù)剛剛的socket連接,管道建立完成
4.職責(zé)鏈模式:緩存、重試、建立連接等功能存在于攔截器中網(wǎng)絡(luò)請求相關(guān),主要是網(wǎng)絡(luò)請求優(yōu)化。網(wǎng)絡(luò)請求的時候遇到的問題
線程同步的問題,常用的線程同步1.sycn:保證了原子性、可見性、有序性
2.鎖:保證了原子性、可見性、有序性
1.自旋鎖:可以使線程在沒有取得鎖的時候,不被掛起,而轉(zhuǎn)去執(zhí)行一個空循環(huán)。
1.優(yōu)點:線程被掛起的幾率減少,線程執(zhí)行的連貫性加強(qiáng)。用于對于鎖競爭不是很激烈,鎖占用時間很短的并發(fā)線程。
2.缺點:過多浪費CPU時間,有一個線程連續(xù)兩次試圖獲得自旋鎖引起死鎖
2.阻塞鎖:沒得到鎖的線程等待或者掛起,Sycn、Lock
3.可重入鎖:一個線程可多次獲取該鎖,Sycn、Lock
4.悲觀鎖:每次去拿數(shù)據(jù)的時候都認(rèn)為別人會修改,所以會阻塞全部其他線程 Sycn、Lock
5.樂觀鎖:每次去拿數(shù)據(jù)的時候都認(rèn)為別人不會修改,所以不會上鎖,但是在更新的時候會判斷一下在此期間別人有沒有去更新這個數(shù)據(jù),可以使用版本號等機(jī)制。cas
6.顯示鎖和內(nèi)置鎖:顯示鎖用Lock來定義、內(nèi)置鎖用synchronized。
7.讀-寫鎖:為了提高性能,Java提供了讀
3.volatile
1.只能保證可見性,不能保證原子性
2.自增操作有三步,此時多線程寫會出現(xiàn)問題
4.cas
1.操作:內(nèi)存值V、舊的預(yù)期值A(chǔ)、要修改的值B,當(dāng)且僅當(dāng)預(yù)期值A(chǔ)和內(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識別不出變化,還是認(rèn)為沒有其他線程在修改V,此時就會有問題
4.局限解決:將V帶上版本。
5.線程不安全到底是怎么回事:
1.一個線程寫,多個線程讀的時候,會造成寫了一半就去讀
2.多線程寫,會造成臟數(shù)據(jù)
Asynctask和線程池,GC相關(guān)(怎么判斷哪些內(nèi)存該GC,GC算法)1.Asynctask:異步任務(wù)類,單線程線程池+Handler
2.線程池:
1.ThreadPoolExecutor:通過Executors可以構(gòu)造單線程池、固定數(shù)目線程池、不固定數(shù)目線程池。
2.ScheduledThreadPoolExecutor:可以延時調(diào)用線程或者延時重復(fù)調(diào)度線程。
3.GC相關(guān):重要
1.搜索算法:
1.引用計數(shù)
2.圖搜索,可達(dá)性分析
2.回收算法:
1.標(biāo)記清除復(fù)制:用于青年代
2.標(biāo)記整理:用于老年代
3.堆分區(qū):
1.青年區(qū)eden 80%、survivor1 10%、survivor2 10%
2.老年區(qū)
4.虛擬機(jī)棧分區(qū):
1.局部變量表
2.操作數(shù)棧
3.動態(tài)鏈接
4.方法返回地址
5.GC Roots:
1.虛擬機(jī)棧(棧楨中的本地變量表)中的引用的對象
2.方法區(qū)中的類靜態(tài)屬性引用的對象
3.方法區(qū)中的常量引用的對象
4.本地方法棧中JNI的引用的對象
1.加載時機(jī):創(chuàng)建實例、訪問靜態(tài)變量或方法、反射、加載子類之前
2.驗證:驗證文件格式、元數(shù)據(jù)、字節(jié)碼、符號引用的正確性
3.加載:根據(jù)全類名獲取文件字節(jié)流、將字節(jié)流轉(zhuǎn)化為靜態(tài)儲存結(jié)構(gòu)放入方法區(qū)、生成class對象
4.準(zhǔn)備:在堆上為靜態(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耦合嚴(yán)重
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è)務(wù)邏輯可以多帶帶拿來測試
2.一個view 對應(yīng)一個 viewModel 業(yè)務(wù)邏輯可以分離,不會出現(xiàn)全能類
3.數(shù)據(jù)和界面綁定了,不用寫垃圾代碼,但是復(fù)用起來不舒服
apk瘦身:1.classes.dex:通過代碼混淆,刪掉不必要的jar包和代碼實現(xiàn)該文件的優(yōu)化
2.資源文件:通過Lint工具掃描代碼中沒有使用到的靜態(tài)資源
3.圖片資源:使用tinypng和webP,下面詳細(xì)介紹圖片資源優(yōu)化的方案,矢量圖
4.SO文件將不用的去掉,目前主流app一般只放一個arm的so包
1.只要是主線程耗時的操作就會ARN 如io
2.broadcast超時時間為10秒 按鍵無響應(yīng)的超時時間為5秒 前臺service無響應(yīng)的超時時間為20秒,后臺service為200秒
1.P 消耗內(nèi)存小
2.網(wǎng)絡(luò)傳輸用S 程序內(nèi)使用P
3.S將數(shù)據(jù)持久化方便
4.S使用了反射 容易觸發(fā)垃圾回收 比較慢
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對象.
1.只要是主線程耗時的操作就會ARN 如io
2.broadcast超時時間為10秒 按鍵無響應(yīng)的超時時間為5秒 前臺service無響應(yīng)的超時時間為20秒,后臺service為200秒
1.classes.dex:通過代碼混淆,刪掉不必要的jar包和代碼實現(xiàn)該文件的優(yōu)化
2.資源文件:通過Lint工具掃描代碼中沒有使用到的靜態(tài)資源
3.圖片資源:使用tinypng和webP,下面詳細(xì)介紹圖片資源優(yōu)化的方案,矢量圖
4.SO文件將不用的去掉,目前主流app一般只放一個arm的so包
#### 閱讀更多
20+個很棒的Android開源項目
我是如何進(jìn)入Facebook的?
2018年Android面試題含答案—適合中高級(下)
看完你就該會git了(手把手教你用vue+node+mongodb搭建一個小商城
相信自己,沒有做不到的,只有想不到的文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請注明本文地址:http://systransis.cn/yun/76545.html
摘要:我沒有什么本事,人也丑,也不會忽悠,只能硬著頭皮學(xué)習(xí)了。最近計劃學(xué)習(xí)后臺,因為最近接了私活的問題,好多都要后臺和前端一起做。 我沒有什么本事,人也丑,也不會忽悠,只能硬著頭皮學(xué)習(xí)了。最近計劃學(xué)習(xí)Java后臺,因為最近接了私活的問題,好多都要Java后臺和前端一起做。平常我在做什么,當(dāng)然是忙著賺錢了 除了敲代碼,你還有什么副業(yè)嗎?接了活自己還要找開發(fā)Java后臺開發(fā)的,為什么我自己不會呢...
摘要:我沒有什么本事,人也丑,也不會忽悠,只能硬著頭皮學(xué)習(xí)了。最近計劃學(xué)習(xí)后臺,因為最近接了私活的問題,好多都要后臺和前端一起做。 我沒有什么本事,人也丑,也不會忽悠,只能硬著頭皮學(xué)習(xí)了。最近計劃學(xué)習(xí)Java后臺,因為最近接了私活的問題,好多都要Java后臺和前端一起做。平常我在做什么,當(dāng)然是忙著賺錢了 除了敲代碼,你還有什么副業(yè)嗎?接了活自己還要找開發(fā)Java后臺開發(fā)的,為什么我自己不會呢...
摘要:我沒有什么本事,人也丑,也不會忽悠,只能硬著頭皮學(xué)習(xí)了。最近計劃學(xué)習(xí)后臺,因為最近接了私活的問題,好多都要后臺和前端一起做。 我沒有什么本事,人也丑,也不會忽悠,只能硬著頭皮學(xué)習(xí)了。最近計劃學(xué)習(xí)Java后臺,因為最近接了私活的問題,好多都要Java后臺和前端一起做。平常我在做什么,當(dāng)然是忙著賺錢了 除了敲代碼,你還有什么副業(yè)嗎?接了活自己還要找開發(fā)Java后臺開發(fā)的,為什么我自己不會呢...
閱讀 1216·2021-09-03 10:44
閱讀 617·2019-08-30 13:13
閱讀 2808·2019-08-30 13:11
閱讀 1976·2019-08-30 12:59
閱讀 1043·2019-08-29 15:32
閱讀 1607·2019-08-29 15:25
閱讀 1003·2019-08-29 12:24
閱讀 1290·2019-08-27 10:58