久久99久久人婷婷精品综合_超碰aⅴ人人做人人爽欧美_亚洲电影第三页_日韩欧美一中文字暮专区_波多野结衣的一区二区三区_婷婷在线播放_人人视频精品_国产精品日韩精品欧美精品_亚洲免费黄色_欧美性猛交xxxxxxxx

Android基礎(chǔ)面試題有哪些-創(chuàng)新互聯(lián)

本文小編為大家詳細(xì)介紹“Android基礎(chǔ)面試題有哪些”,內(nèi)容詳細(xì),步驟清晰,細(xì)節(jié)處理妥當(dāng),希望這篇“Android基礎(chǔ)面試題有哪些”文章能幫助大家解決疑惑,下面跟著小編的思路慢慢深入,一起來(lái)學(xué)習(xí)新知識(shí)吧。

成都創(chuàng)新互聯(lián)公司專(zhuān)注于企業(yè)全網(wǎng)整合營(yíng)銷(xiāo)推廣、網(wǎng)站重做改版、西湖網(wǎng)站定制設(shè)計(jì)、自適應(yīng)品牌網(wǎng)站建設(shè)、H5頁(yè)面制作商城網(wǎng)站建設(shè)、集團(tuán)公司官網(wǎng)建設(shè)、外貿(mào)網(wǎng)站建設(shè)、高端網(wǎng)站制作、響應(yīng)式網(wǎng)頁(yè)設(shè)計(jì)等建站業(yè)務(wù),價(jià)格優(yōu)惠性價(jià)比高,為西湖等各大城市提供網(wǎng)站開(kāi)發(fā)制作服務(wù)。

一 性能優(yōu)化

1.如何對(duì) Android 應(yīng)用進(jìn)行性能分析

android 性能主要之響應(yīng)速度 和UI刷新速度。

可以參考博客:Android系統(tǒng)性能調(diào)優(yōu)工具介紹

首先從函數(shù)的耗時(shí)來(lái)說(shuō),有一個(gè)工具TraceView 這是androidsdk自帶的工作,用于測(cè)量函數(shù)耗時(shí)的。

UI布局的分析,可以有2塊,一塊就是Hierarchy Viewer 可以看到View的布局層次,以及每個(gè)View刷新加載的時(shí)間。

這樣可以很快定位到那塊layout & View 耗時(shí)最長(zhǎng)。

還有就是通過(guò)自定義View來(lái)減少view的層次。

2.什么情況下會(huì)導(dǎo)致內(nèi)存泄露

內(nèi)存泄露是個(gè)折騰的問(wèn)題。

什么時(shí)候會(huì)發(fā)生內(nèi)存泄露??jī)?nèi)存泄露的根本原因:長(zhǎng)生命周期的對(duì)象持有短生命周期的對(duì)象。短周期對(duì)象就無(wú)法及時(shí)釋放。

I. 靜態(tài)集合類(lèi)引起內(nèi)存泄露

主要是hashmap,Vector等,如果是靜態(tài)集合 這些集合沒(méi)有及時(shí)setnull的話,就會(huì)一直持有這些對(duì)象。

II.remove 方法無(wú)法刪除set集 Objects.hash(firstName, lastName);

經(jīng)過(guò)測(cè)試,hashcode修改后,就沒(méi)有辦法remove了。

III. observer 我們?cè)谑褂帽O(jiān)聽(tīng)器的時(shí)候,往往是addxxxlistener,但是當(dāng)我們不需要的時(shí)候,忘記removexxxlistener,就容易內(nèi)存leak。

廣播沒(méi)有unregisterrecevier

IV.各種數(shù)據(jù)鏈接沒(méi)有關(guān)閉,數(shù)據(jù)庫(kù)contentprovider,io,sokect等。cursor

V.內(nèi)部類(lèi):

java中的內(nèi)部類(lèi)(匿名內(nèi)部類(lèi)),會(huì)持有宿主類(lèi)的強(qiáng)引用this。

所以如果是new Thread這種,后臺(tái)線程的操作,當(dāng)線程沒(méi)有執(zhí)行結(jié)束時(shí),activity不會(huì)被回收。

Context的引用,當(dāng)TextView 等等都會(huì)持有上下文的引用。如果有static drawable,就會(huì)導(dǎo)致該內(nèi)存無(wú)法釋放。

VI.單例

單例 是一個(gè)全局的靜態(tài)對(duì)象,當(dāng)持有某個(gè)復(fù)制的類(lèi)A是,A無(wú)法被釋放,內(nèi)存leak。

3.如何避免 OOM 異常

首先OOM是什么?

當(dāng)程序需要申請(qǐng)一段“大”內(nèi)存,但是虛擬機(jī)沒(méi)有辦法及時(shí)的給到,即使做了GC操作以后

這就會(huì)拋出 OutOfMemoryException 也就是OOM

Android的OOM怎么樣?

為了減少單個(gè)APP對(duì)整個(gè)系統(tǒng)的影響,android為每個(gè)app設(shè)置了一個(gè)內(nèi)存上限。

public void getMemoryLimited(Activity context)   {       ActivityManager activityManager =(ActivityManager)context.getSystemService(Context.ACTIVITY_SERVICE);       System.out.println(activityManager.getMemoryClass());       System.out.println(activityManager.getLargeMemoryClass());       System.out.println(Runtime.getRuntime().maxMemory()/(1024*1024));   }

HTC M7實(shí)測(cè),192M上限。512M 一般情況下,192M就是上限,但是由于某些特殊情況,android允許使用一個(gè)更大的RAM。

如何避免OOM
減少內(nèi)存對(duì)象的占用

I.ArrayMap/SparseArray代替hashmap

II.避免在android里面使用Enum

III.減少bitmap的內(nèi)存占用

  • inSampleSize:縮放比例,在把圖片載入內(nèi)存之前,我們需要先計(jì)算出一個(gè)合適的縮放比例,避免不必要的大圖載入。

  • decode format:解碼格式,選擇ARGB_8888/RBG_565/ARGB_4444/ALPHA_8,存在很大差異。

IV.減少資源圖片的大小,過(guò)大的圖片可以考慮分段加載

內(nèi)存對(duì)象的重復(fù)利用

大多數(shù)對(duì)象的復(fù)用,都是利用對(duì)象池的技術(shù)。

I.listview/gridview/recycleview contentview的復(fù)用

II.inBitmap 屬性對(duì)于內(nèi)存對(duì)象的復(fù)用ARGB_8888/RBG_565/ARGB_4444/ALPHA_8

這個(gè)方法在某些條件下非常有用,比如要加載上千張圖片的時(shí)候。

III.避免在ondraw方法里面 new對(duì)象

IV.StringBuilder 代替+

4.Android 中如何捕獲未捕獲的異常

Android基礎(chǔ)面試題有哪些

CrashHandler

關(guān)鍵是實(shí)現(xiàn)Thread.UncaughtExceptionHandler

然后是在application的oncreate里面注冊(cè)。

5.ANR 是什么?怎樣避免和解決 ANR(重要)

ANR->Application Not Responding

也就是在規(guī)定的時(shí)間內(nèi),沒(méi)有響應(yīng)。

三種類(lèi)型:

1). KeyDispatchTimeout(5 seconds) —主要類(lèi)型按鍵或觸摸事件在特定時(shí)間內(nèi)無(wú)響應(yīng)

2). BroadcastTimeout(10 seconds) —BroadcastReceiver在特定時(shí)間內(nèi)無(wú)法處理完成

3). ServiceTimeout(20 seconds) —小概率類(lèi)型 Service在特定的時(shí)間內(nèi)無(wú)法處理完成

為什么會(huì)超時(shí):事件沒(méi)有機(jī)會(huì)處理 & 事件處理超時(shí)

怎么避免ANR

ANR的關(guān)鍵

是處理超時(shí),所以應(yīng)該避免在UI線程,BroadcastReceiver 還有service主線程中,處理復(fù)雜的邏輯和計(jì)算

而交給work thread操作。

1)避免在activity里面做耗時(shí)操作,oncreate & onresume

2)避免在onReceiver里面做過(guò)多操作

3)避免在Intent Receiver里啟動(dòng)一個(gè)Activity,因?yàn)樗鼤?huì)創(chuàng)建一個(gè)新的畫(huà)面,并從當(dāng)前用戶正在運(yùn)行的程序上搶奪焦點(diǎn)。

4)盡量使用handler來(lái)處理UI thread & workthread的交互。

如何解決ANR

首先定位ANR發(fā)生的log:

04-01 13:12:11.572 I/InputDispatcher( 220): Application is not responding:Window{2b263310com.android.email/com.android.email.activity.SplitScreenActivitypaused=false}.  5009.8ms since event, 5009.5ms since waitstartedCPUusage from 4361ms to 699ms ago ----CPU在ANR發(fā)生前的使用情況04-0113:12:15.872 E/ActivityManager(  220): 100%TOTAL: 4.8% user + 7.6% kernel + 87% iowait04-0113:12:15.872 E/ActivityManager(  220): CPUusage from 3697ms to 4223ms later:-- ANR后CPU的使用量

從log可以看出,cpu在做大量的io操作。

所以可以查看io操作的地方。

當(dāng)然,也有可能cpu占用不高,那就是 主線程被block住了。

6.Android 線程間通信有哪幾種方式

1)共享變量(內(nèi)存)

2)管道

3)handle機(jī)制

runOnUiThread(Runnable)

view.post(Runnable)

7.Devik 進(jìn)程,linux 進(jìn)程,線程的區(qū)別

Dalvik進(jìn)程。

每一個(gè)android app都會(huì)獨(dú)立占用一個(gè)dvm虛擬機(jī),運(yùn)行在linux系統(tǒng)中。

所以dalvik進(jìn)程和linux進(jìn)程是可以理解為一個(gè)概念。

8.描述一下 android 的系統(tǒng)架構(gòu)

從小到上就是:

linux kernel,lib dalvik vm ,application framework, app

9.android 應(yīng)用對(duì)內(nèi)存是如何限制的?我們應(yīng)該如何合理使用內(nèi)存?

activitymanager.getMemoryClass() 獲取內(nèi)存限制。

關(guān)于合理使用內(nèi)存,其實(shí)就是避免OOM & 內(nèi)存泄露中已經(jīng)說(shuō)明。

10. 簡(jiǎn)述 android 應(yīng)用程序結(jié)構(gòu)是哪些

1)main code

  1. unit test

3)mianifest

4)res->drawable,drawable-xxhdpi,layout,value,mipmap

mipmap 是一種很早就有的技術(shù)了,翻譯過(guò)來(lái)就是紋理映射技術(shù).

google建議只把啟動(dòng)圖片放入。

5)lib

6)color

11.請(qǐng)解釋下 Android 程序運(yùn)行時(shí)權(quán)限與文件系統(tǒng)權(quán)限的區(qū)別

文件的系統(tǒng)權(quán)限是由linux系統(tǒng)規(guī)定的,只讀,讀寫(xiě)等。

運(yùn)行時(shí)權(quán)限,是對(duì)于某個(gè)系統(tǒng)上的app的訪問(wèn)權(quán)限,允許,拒絕,詢問(wèn)。該功能可以防止非法的程序訪問(wèn)敏感的信息。

12.Framework 工作方式及原理,Activity 是如何生成一個(gè) view 的,機(jī)制是什么

Framework是android 系統(tǒng)對(duì) linux kernel,lib庫(kù)等封裝,提供WMS,AMS,bind機(jī)制,handler-message機(jī)制等方式,供app使用。

簡(jiǎn)單來(lái)說(shuō)framework就是提供app生存的環(huán)境。

1)Activity在attch方法的時(shí)候,會(huì)創(chuàng)建一個(gè)phonewindow(window的子類(lèi))

2)onCreate中的setContentView方法,會(huì)創(chuàng)建DecorView

3)DecorView 的addview方法,會(huì)把layout中的布局加載進(jìn)來(lái)。

13.多線程間通信和多進(jìn)程之間通信有什么不同,分別怎么實(shí)現(xiàn)

線程間的通信可以參考第6點(diǎn)。

進(jìn)程間的通信:bind機(jī)制(IPC->AIDL),linux級(jí)共享內(nèi)存,boradcast,

Activity 之間,activity & serview之間的通信,無(wú)論他們是否在一個(gè)進(jìn)程內(nèi)。

14.Android 屏幕適配

屏幕適配的方式:xxxdpi, wrap_content,match_parent. 獲取屏幕大小,做處理。

dp來(lái)適配屏幕,sp來(lái)確定字體大小

drawable-xxdpi, values-1280*1920等 這些就是資源的適配。

wrap_content,match_parent, 這些是view的自適應(yīng)

weight,這是權(quán)重的適配。

15.什么是 AIDL 以及如何使用

Android Interface Definition Language

AIDL是使用bind機(jī)制來(lái)工作。

參數(shù):

java原生參數(shù)

String

parcelable

list & map 元素 需要支持AIDL

16.Handler 機(jī)制

參考:android 進(jìn)程/線程管理(一)——消息機(jī)制的框架 這個(gè)系類(lèi)。

17.事件分發(fā)機(jī)制

android 事件分發(fā)機(jī)制

18.子線程發(fā)消息到主線程進(jìn)行更新 UI,除了 handler 和 AsyncTask,還有什么

EventBus,廣播,view.post, runinUiThread

但是無(wú)論各種花樣,本質(zhì)上就2種:handler機(jī)制 + 廣播

19.子線程中能不能 new handler?為什么

必須可以。子線程 可以new 一個(gè)mainHandler,然后發(fā)送消息到UI Thread。

20.Android 中的動(dòng)畫(huà)有哪幾類(lèi),它們的特點(diǎn)和區(qū)別是什么

視圖動(dòng)畫(huà),或者說(shuō)補(bǔ)間動(dòng)畫(huà)。只是視覺(jué)上的一個(gè)效果,實(shí)際view屬性沒(méi)有變化,性能好,但是支持方式少。

屬性動(dòng)畫(huà),通過(guò)變化屬性來(lái)達(dá)到動(dòng)畫(huà)的效果,性能略差,支持點(diǎn)擊等事件。android 3.0

幀動(dòng)畫(huà),通過(guò)drawable一幀幀畫(huà)出來(lái)。

Gif動(dòng)畫(huà),原理同上,canvas畫(huà)出來(lái)。

21.如何修改 Activity 進(jìn)入和退出動(dòng)畫(huà)

overridePendingTransition

22.SurfaceView & View 的區(qū)別

view的更新必須在UI thread中進(jìn)行

surfaceview會(huì)單獨(dú)有一個(gè)線程做ui的更新。

surfaceview 支持open GL繪制。

二項(xiàng)目框架的使用

23.開(kāi)發(fā)中都使用過(guò)哪些框架、平臺(tái)

I.EventBus 事件分發(fā)機(jī)制,由handler實(shí)現(xiàn),線程間通信

II.xUtils->DbUtils,ViewUtils,HttpUtils,BitmapUtils

III.百度地圖

IV.volley

V.fastjson

VI.picciso

VII.友盟

VIII.zxing

IX.Gson

24.使用過(guò)那些自定義View

pull2RefreshListView

25.自定義控件:繪制圓環(huán)的實(shí)現(xiàn)過(guò)程

public class CycleView extends View {   Paint mPaint = new Paint(); public CycleView(Context context) { this(context, null);   } public CycleView(Context context, AttributeSet attrs) { super(context, attrs);       initView();   } private void initView() {       mPaint.setAntiAlias(true);       mPaint.setStyle(Paint.Style.STROKE);       mPaint.setStrokeWidth(20);   }   @Override protected void onDraw(Canvas canvas) { super.onDraw(canvas);       canvas.drawCircle(100,100,50,mPaint);   }}

讀到這里,這篇“Android基礎(chǔ)面試題有哪些”文章已經(jīng)介紹完畢,想要掌握這篇文章的知識(shí)點(diǎn)還需要大家自己動(dòng)手實(shí)踐使用過(guò)才能領(lǐng)會(huì),如果想了解更多相關(guān)內(nèi)容的文章,歡迎關(guān)注創(chuàng)新互聯(lián)-成都網(wǎng)站建設(shè)公司行業(yè)資訊頻道。

網(wǎng)站名稱(chēng):Android基礎(chǔ)面試題有哪些-創(chuàng)新互聯(lián)
URL網(wǎng)址:http://www.js-pz168.com/article8/docjip.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供微信公眾號(hào)網(wǎng)站改版網(wǎng)站設(shè)計(jì)小程序開(kāi)發(fā)關(guān)鍵詞優(yōu)化網(wǎng)站維護(hù)

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來(lái)源: 創(chuàng)新互聯(lián)

網(wǎng)站優(yōu)化排名
久久99久久人婷婷精品综合_超碰aⅴ人人做人人爽欧美_亚洲电影第三页_日韩欧美一中文字暮专区_波多野结衣的一区二区三区_婷婷在线播放_人人视频精品_国产精品日韩精品欧美精品_亚洲免费黄色_欧美性猛交xxxxxxxx
国产精品黄色在线观看| 九色|91porny| 国产成人亚洲精品狼色在线| 91蜜桃网站免费观看| 性高潮久久久久久久久| 91精品国产日韩91久久久久久| 欧美国产国产综合| 青青草91视频| 波多野结衣成人在线| 色网站国产精品| 久久久久久久综合狠狠综合| 首页欧美精品中文字幕| 97久久超碰国产精品电影| 亚洲人成网站在线播放2019| 精品久久人人做人人爰| 亚洲成人精品一区二区| 99re66热这里只有精品3直播 | 国产日韩欧美精品一区| 日韩1区2区3区| 中文字幕精品—区二区四季| 亚洲成人在线观看视频| 97国产一区二区| 色8久久人人97超碰香蕉987| 国产三级欧美三级日产三级99 | av毛片久久久久**hd| 亚洲欧洲久久| 国产欧美日韩不卡免费| 久久99国产精品久久| 久久精品日产第一区二区三区乱码 | 国产精品国产三级国产aⅴ原创| 激情综合色播五月| 欧美二级三级| 精品国产一区二区三区四区四| 偷拍一区二区三区| 超碰97在线资源| 欧美日韩国产成人在线91| 亚洲乱码中文字幕| 99re6这里只有精品视频在线观看| 日本乱人伦一区| 亚洲欧美精品午睡沙发| 成人动漫一区二区三区| 91福利在线播放| 亚洲精品国产高清久久伦理二区 | 欧美一级一区二区| 午夜私人影院久久久久| 国产精品乱码视频| 91精品国产综合久久精品麻豆| 亚洲高清不卡在线| 国产精品久久久久免费| 日韩欧美国产高清| 久久精品国产999大香线蕉| 日本一区不卡| 国产精品美女久久久久久久网站| 国产精品 日产精品 欧美精品| 亚洲一区在线免费| 1区2区3区国产精品| 99re热视频精品| 91精品国产一区二区| 奇米在线7777在线精品| 日本在线成人一区二区| 国产精品女主播av| av一区二区三区在线| 欧美日本乱大交xxxxx| 视频一区欧美精品| 日本一区二区三区四区高清视频| 中文字幕欧美三区| 99精品一区二区三区| 日韩一级在线观看| 精品一区二区三区在线观看国产| 亚洲欧洲一二三| 亚洲精品ww久久久久久p站| 国产精品免费视频一区二区| 欧美精品一区二区三区视频| 国产成人自拍在线| 欧美老年两性高潮| 久久精品国产99国产| 色av成人天堂桃色av| 亚洲一区二区视频在线| 麻豆成人av| 中文字幕一区二区三区在线播放| 91欧美激情一区二区三区成人| 日韩精品一区二区三区swag| 国产精品原创巨作av| 欧美日韩亚洲综合在线| 美女精品一区二区| 日本道色综合久久| 日韩avvvv在线播放| 伊人久久99| 视频一区二区中文字幕| 一区二区精品视频| 亚洲va韩国va欧美va精品| 少妇精品久久久久久久久久| 有码一区二区三区| 欧美亚洲免费在线| 一区二区三区蜜桃| 欧美午夜视频在线| 亚洲精品高清在线| 欧美视频1区| 亚洲国产精品天堂| 亚洲欧洲一区二区福利| 午夜久久福利影院| 中日韩在线视频| 免费一级片91| 欧美日韩国产一级二级| 国产麻豆精品theporn| 欧美一级高清片在线观看| 国产91综合一区在线观看| 日韩手机在线导航| 99在线精品一区二区三区| 久久综合五月天婷婷伊人| 91成人免费在线观看| 欧美国产禁国产网站cc| 精品国产一区二区三区麻豆免费观看完整版 | 国产欧美精品一区| 精品国产一区二区三区四区精华| 亚洲人成在线观看一区二区| 欧美精品一区二区三区在线看午夜| 亚洲综合视频网| 综合视频免费看| 精品一区二区在线看| 91麻豆精品国产自产在线观看一区| 高清成人在线观看| 久久精品日产第一区二区三区高清版 | 91麻豆精品国产91久久久使用方法 | 国产三级精品在线| 好吊色欧美一区二区三区| 亚洲精品乱码久久久久| 色综合久久综合| 国产在线日韩欧美| 欧美v日韩v国产v| 国产a一区二区| 亚洲精品成人精品456| 色综合久久中文字幕综合网| 国内一区二区视频| 亚洲精品在线免费观看视频| 国产精品免费视频一区二区| 亚洲狠狠丁香婷婷综合久久久| 一本久久精品一区二区| 国产一区二区精品久久91| 精品国产1区2区3区| 精品国产乱码久久久久| 亚洲国产精品一区二区久久| 欧美日韩一级黄| 97久久超碰国产精品| 亚洲摸摸操操av| 91成人免费在线视频| 丁香激情综合国产| 国产精品久久久久久久久晋中| 色综合久久88色综合天天提莫| 久久99热这里只有精品| 亚洲精品在线观| 欧美综合激情| 国内精品伊人久久久久av一坑| 久久品道一品道久久精品| 免费成人av网站| 开心九九激情九九欧美日韩精美视频电影| 欧美一级欧美一级在线播放| 好看的日韩精品视频在线| 日韩精品一二区| 欧美岛国在线观看| 欧美国产综合视频| 狠狠色丁香九九婷婷综合五月| 久久综合国产精品| 日韩欧美亚洲日产国| 国产一区二区在线观看视频| 欧美高清在线一区二区| 一本一道久久a久久精品| 成人久久久精品乱码一区二区三区| 最新不卡av在线| 欧美日韩国产一区二区三区地区| 99三级在线| 日韩精彩视频在线观看| 26uuuu精品一区二区| 日韩在线电影一区| 处破女av一区二区| 亚洲黄色在线视频| 91麻豆精品国产91久久久使用方法 | 欧美三级电影在线观看| 成人欧美一区二区| 青青草91视频| 中文字幕欧美日韩一区| 在线观看日韩毛片| a级国产乱理论片在线观看99| 日韩成人免费在线| 国产视频视频一区| 在线观看国产一区二区| 国产高清精品一区二区| 久久国产精品无码网站| 国产精品免费aⅴ片在线观看| 欧美色视频在线| 国产综合18久久久久久| 国产在线视频一区二区三区| 亚洲人成精品久久久久久 | 国产自产高清不卡| 亚洲免费观看在线视频| 日韩三级免费观看| 亚洲巨乳在线观看| 99影视tv| 国内精品国产成人国产三级粉色 | 欧美h视频在线|