成人国产在线小视频_日韩寡妇人妻调教在线播放_色成人www永久在线观看_2018国产精品久久_亚洲欧美高清在线30p_亚洲少妇综合一区_黄色在线播放国产_亚洲另类技巧小说校园_国产主播xx日韩_a级毛片在线免费

資訊專欄INFORMATION COLUMN

2019最新Android面試題

plus2047 / 2334人閱讀

摘要:若攔截事件返回為,表示攔截,事件不會向下層的或者傳遞,表示不攔截,繼續(xù)分發(fā)事件。五注冊反注冊未成對使用引起的內(nèi)存泄漏。七集合對象沒有及時清理引起的內(nèi)存泄漏。

原文鏈接:https://blog.csdn.net/wen_hah... 
版權聲明:本文為博主原創(chuàng)文章,轉載請附上博文鏈接!
前言

金三銀四到來了,找工作的好時候到了,小伙伴們是不是都在忙著找工作呢,小弟前一陣也是忙著在找工作,面試了好多公司,所幸的是進到了自己心儀的公司,也是很幸運的。下面我將自己親身實戰(zhàn)的面試題及收到的面試題總結并分享答案出來。歡迎各位大哥指導、指點。

下面這些只是Android方面的知識,如果有需要Java方面的面試題的話,可以在下面留言。

1.Activity生命周期(這個是必問的)

onCreate() 創(chuàng)建活動,做一些數(shù)據(jù)初始化操作

onStart() 由不可見變?yōu)榭梢?/p>

onResume() 可以與用戶進行交互,位于棧頂

onPause() 暫停,啟動或恢復另一個活動時調(diào)用

onStop() 停止,變?yōu)椴豢梢?/p>

onDestroy() 銷毀

onRestart() 由停止狀態(tài)變?yōu)檫\行狀態(tài)

2.Fragment生命周期 (這個有可能會問到,問的機率不是很大)

3.Service生命周期

onCreate()

首次創(chuàng)建服務時,系統(tǒng)將調(diào)用此方法。如果服務已在運行,則不會調(diào)用此方法,該方法只調(diào)用一次。

onStartCommand()

當另一個組件通過調(diào)用startService()請求啟動服務時,系統(tǒng)將調(diào)用此方法。

onDestroy()

當服務不再使用且將被銷毀時,系統(tǒng)將調(diào)用此方法。

onBind()

當另一個組件通過調(diào)用bindService()與服務綁定時,系統(tǒng)將調(diào)用此方法。

onUnbind()

當另一個組件通過調(diào)用unbindService()與服務解綁時,系統(tǒng)將調(diào)用此方法。

onRebind()

當舊的組件與服務解綁后,另一個新的組件與服務綁定,onUnbind()返回true時,系統(tǒng)將調(diào)用此方法。

4.Service啟動方式(問到Service,這個肯定是要問到的)

1.startService

①.定義一個類繼承service

②.在manifest.xml文件中配置該service

③.使用context的startService(intent)啟動該service

④.不再使用時,調(diào)用stopService(Intent)停止該服務

2.bindService

①.創(chuàng)建bindService服務段,繼承自service并在類中,創(chuàng)建一個實現(xiàn)binder接口的實例對象并提供公共方法給客戶端調(diào)用

②.從onbind()回調(diào)方法返回此binder實例

③.在客戶端中,從onserviceconnected()回調(diào)方法接收binder,并使用提供的方法調(diào)用綁定服務

5.Activity的啟動方式(偶爾會問)

①.standard模式

a.Activity的默認啟動模式

b.每啟動一個Activity就會在棧頂創(chuàng)建一個新的實例。例如:鬧鐘程序

缺點:當Activity已經(jīng)位于棧頂時,而再次啟動Activity時還需要在創(chuàng)建一個新的實例,不能直接復用。

②.singleTop模式

特點:該模式會判斷要啟動的Activity實例是否位于棧頂,如果位于棧頂直接復用,否則創(chuàng)建新的實例。 例如:瀏覽器的書簽

?缺點:如果Activity并未處于棧頂位置,則可能還會創(chuàng)建多個實例。

③.singleTask模式

特點:使Activity在整個應用程序中只有一個實例。每次啟動Activity時系統(tǒng)首先檢查棧中是否存在當前Activity實例,如果存在

則直接復用,并把當前Activity之上所有實例全部出棧。例如:瀏覽器主界面

④.singleInstance模式

特點:該模式的Activity會啟動一個新的任務棧來管理Activity實例,并且該勢力在整個系統(tǒng)中只有一個。無論從那個任務棧中啟動該Activity,都會是該Activity所在的任務棧轉移到前臺,從而使Activity顯示。主要作用是為了在不同程序中共享一個Activity

6.Touch事件傳遞機制

在我們點擊屏幕時,會有下列事件發(fā)生:

Activity調(diào)用dispathTouchEvent()方法,把事件傳遞給Window;

Window再將事件交給DecorView(DecorView是View的根布局);

DecorView再傳遞給ViewGroup;

Activity ——> Window ——> DecorView ——> ViewGroup——> View

事件分發(fā)的主要有三個關鍵方法

dispatchTouchEvent() 分發(fā)

onInterceptTouchEvent() 攔截 ,只有ViewGroup獨有此方法

onTouchEvent() 處理觸摸事件

Activity首先調(diào)用dispathTouchEvent()進行分發(fā),接著調(diào)用super向下傳遞

ViewGroup首先調(diào)用dispathTouchEvent()進行分發(fā),接著會調(diào)用onInterceptTouchEvent()(攔截事件)。若攔截事件返回為true,表示攔截,事件不會向下層的ViewGroup或者View傳遞;false,表示不攔截,繼續(xù)分發(fā)事件。默認是false,需要提醒一下,View是沒有onInterceptTouchEvent()方法的

事件在ViewGroup和ViewGroup、ViewGroup和View之間進行傳遞,最終到達View;

View調(diào)用dispathTouchEvent()方法,然后在OnTouchEvent()進行處理事件;OnTouchEvent() 返回true,表示消耗此事件,不再向下傳遞;返回false,表示不消耗事件,交回上層處理。

7.介紹下實現(xiàn)一個自定義View的基本流程

①.自定義View的屬性 編寫attr.xml文件

②.在layout布局文件中引用,同時引用命名空間

③.在View的構造方法中獲得我們自定義的屬性 ,在自定義控件中進行讀?。嬙旆椒玫絘ttr.xml文件值)

④.重寫onMesure

⑥.重寫onDraw

8.Android中的動畫有哪些

逐幀動畫(Frame Animation)

加載一系列Drawable資源來創(chuàng)建動畫,簡單來說就是播放一系列的圖片來實現(xiàn)動畫效果,可以自定義每張圖片的持續(xù)時間

補間動畫(Tween Animation)

Tween可以對View對象實現(xiàn)一系列動畫效果,比如平移,縮放,旋轉,透明度等。但是它并不會改變View屬性的值,只是改變了View的繪制的位置,比如,一個按鈕在動畫過后,不在原來的位置,但是觸發(fā)點擊事件的仍然是原來的坐標。

屬性動畫(Property Animation)

動畫的對象除了傳統(tǒng)的View對象,還可以是Object對象,動畫結束后,Object對象的屬性值被實實在在的改變了

9.ANR是什么?怎樣避免和解決ANR

Application Not Responding,即應用無響應

出現(xiàn)的原因有三種:

a)KeyDispatchTimeout(5 seconds)主要類型按鍵或觸摸事件在特定時間內(nèi)無響應

b)BroadcastTimeout(10 seconds)BoradcastReceiver在特定的時間內(nèi)無法處理

c)ServiceTimeout(20 seconds)小概率類型Service在特定的時間內(nèi)無法處理完成

避免ANR最核心的一點就是在主線程減少耗時操作。通常需要從那個以下幾個方案下手:

a)使用子線程處理耗時IO操作

b)降低子線程優(yōu)先級,使用Thread或者HandlerThread時,調(diào)用Process.setThreadPriority(Process.THREAD_PRIORITY_BACKGROUND)設置優(yōu)先級,否則仍然會降低程序響應,因為默認Thread的優(yōu)先級和主線程相同

c)使用Handler處理子線程結果,而不是使用Thread.wait()或者Thread.sleep()來阻塞主線程

d)Activity的onCreate和onResume回調(diào)中盡量避免耗時的代碼

e)BroadcastReceiver中onReceiver代碼也要盡量減少耗時操作,建議使用intentService處理。intentService是一個異步的,會自動停止的服務,很好解決了傳統(tǒng)的Service中處理完耗時操作忘記停止并銷毀Service的問題

10.如何優(yōu)化ListView(偶爾會問)

①Item布局,層級越少越好,使用hierarchyview工具查看優(yōu)化。

②復用convertView

③使用ViewHolder

④item中有圖片時,異步加載

⑤快速滑動時,不加載圖片

⑥item中有圖片時,應對圖片進行適當壓縮

⑦實現(xiàn)數(shù)據(jù)的分頁加載

11.設備橫豎屏切換的時候,生面周期的變化(這個偶爾會問)

不設置Activity的android:configChanges時,切屏會重新調(diào)用各個生命周期,切橫屏時會執(zhí)行一次,切豎屏時會執(zhí)行兩次

設置Activity的android:configChanges=”orientation”時,切屏還是會重新調(diào)用各個生命周期,切橫、豎屏時只會執(zhí)行一次

設置Activity的android:configChanges=”orientation|keyboardHidden”時,切屏不會重新調(diào)用各個生命周期,只會執(zhí)行onConfigurationChanged方法

12.AndroidUI的適配

字體使用sp,使用dp,多使用match_parent,wrap_content,weight

圖片資源,不同圖片的的分辨率,放在相應的文件夾下可使用百分比代替。

13.RecyclerView和ListView的區(qū)別(這個是必問的)

RecyclerView可以完成ListView,GridView的效果,還可以完成瀑布流的效果。同時還可以設置列表的滾動方向(垂直或者水平);

RecyclerView中view的復用不需要開發(fā)者自己寫代碼,系統(tǒng)已經(jīng)幫封裝完成了。

RecyclerView可以進行局部刷新。

RecyclerView提供了API來實現(xiàn)item的動畫效果。

在性能上:

如果需要頻繁的刷新數(shù)據(jù),需要添加動畫,則RecyclerView有較大的優(yōu)勢。

如果只是作為列表展示,則兩者區(qū)別并不是很大。

14,Android異步消息處理機制(這個也會經(jīng)常問到)

異步消息處理機制主要是用來解決子線程更新UI的問題

主要有四個部分:

①. Message (消息)中

在線程之間傳遞,可在內(nèi)部攜帶少量信息,用于不同線程之間交換數(shù)據(jù)

可以使用what、arg1、arg2字段攜帶整型數(shù)據(jù)

obj字段攜帶Object對象

②. Handler (處理者)

主要用于發(fā)送和處理消息,sendMessage()用來發(fā)送消息,最終會回到handleMessage()進行處理

③. MessageQueue (消息隊列)

主要存放所有通過Handler發(fā)送的消息,它們會一直存在于隊列中等待被處理

每個線程只有一個MessageQueue

④. Looper (循環(huán)器)

調(diào)用loop()方法后,會不斷從MessageQueue 取出待處理的消息,然后傳遞到handleMessage進行處理

15.內(nèi)存泄漏和內(nèi)存溢出是什么?一般怎么處理內(nèi)存泄漏?

(1)內(nèi)存溢出(OOM)和內(nèi)存泄露(對象無法被回收)的區(qū)別。

(2)引起內(nèi)存泄露的原因

(3)內(nèi)存泄露檢測工具 ------>LeakCanary

內(nèi)存溢出 out of memory:是指程序在申請內(nèi)存時,沒有足夠的內(nèi)存空間供其使用,出現(xiàn)out of memory;比如申請了一個integer,但給它存了long才能存下的數(shù),那就是內(nèi)存溢出。內(nèi)存溢出通俗的講就是內(nèi)存不夠用。

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

內(nèi)存泄露原因以及解決:

一、Handler 引起的內(nèi)存泄漏。

解決:將Handler聲明為靜態(tài)內(nèi)部類,就不會持有外部類SecondActivity的引用,其生命周期就和外部類無關,

如果Handler里面需要context的話,可以通過弱引用方式引用外部類

二、單例模式引起的內(nèi)存泄漏。

解決:Context是ApplicationContext,由于ApplicationContext的生命周期是和app一致的,不會導致內(nèi)存泄漏

三、非靜態(tài)內(nèi)部類創(chuàng)建靜態(tài)實例引起的內(nèi)存泄漏。

解決:把內(nèi)部類修改為靜態(tài)的就可以避免內(nèi)存泄漏了

四、非靜態(tài)匿名內(nèi)部類引起的內(nèi)存泄漏。

解決:將匿名內(nèi)部類設置為靜態(tài)的。

五、注冊/反注冊未成對使用引起的內(nèi)存泄漏。

注冊廣播接受器、EventBus等,記得解綁。

六、資源對象沒有關閉引起的內(nèi)存泄漏。

在這些資源不使用的時候,記得調(diào)用相應的類似close()、destroy()、recycler()、release()等方法釋放。

七、集合對象沒有及時清理引起的內(nèi)存泄漏。

通常會把一些對象裝入到集合中,當不使用的時候一定要記得及時清理集合,讓相關對象不再被引用。

16.圖片加載框架有哪些?他們之間的區(qū)別是什么?(這個也是必問的)

ImageLoader :

優(yōu)點:

① 支持下載進度監(jiān)聽;

② 可以在 View 滾動中暫停圖片加載;

③ 默認實現(xiàn)多種內(nèi)存緩存算法這幾個圖片緩存都可以配置緩存算法,不過 ImageLoader 默認實現(xiàn)了較多緩存算法,如 Size 最大先刪除、使用最少先刪除、最近最少使用、先進先刪除、時間最長先刪除等;

④ 支持本地緩存文件名規(guī)則定義;

缺點:

缺點在于不支持GIF圖片加載, 緩存機制沒有和http的緩存很好的結合, 完全是自己的一套緩存機制

Picasso:

優(yōu)點:

① 自帶統(tǒng)計監(jiān)控功能,支持圖片緩存使用的監(jiān)控,包括緩存命中率、已使用內(nèi)存大小、節(jié)省的流量等。

② 支持優(yōu)先級處理

③ 支持延遲到圖片尺寸計算完成加載

④ 支持飛行模式、并發(fā)線程數(shù)根據(jù)網(wǎng)絡類型而變,手機切換到飛行模式或網(wǎng)絡類型變換時會自動調(diào)整線程池最大并發(fā)數(shù)。

⑤ “無”本地緩存。Picasso 自己沒有實現(xiàn)本地緩存,而由okhttp 去實現(xiàn),這樣的好處是可以通過請求 Response Header 中的 Cache-Control 及 Expired 控制圖片的過期時間。

缺點:

于不支持GIF,默認使用ARGB_8888格式緩存圖片,緩存體積大。

Glide:

優(yōu)點:

① 圖片緩存->媒體緩存 ,支持 Gif、WebP、縮略圖。甚至是 Video。

② 支持優(yōu)先級處理

③ 與 Activity/Fragment 生命周期一致,支持 trimMemory

④ 支持 okhttp、Volley。Glide 默認通過 UrlConnection 獲取數(shù)據(jù),可以配合 okhttp 或是 Volley 使用。實際 ImageLoader、Picasso 也都支持 okhttp、Volley。

⑤ 內(nèi)存友好,內(nèi)存緩存更小圖片,圖片默認使用默認 RGB565 而不是 ARGB888

缺點:

清晰度差,但可以設置

Fresco:

優(yōu)點:

① 圖片存儲在安卓系統(tǒng)的匿名共享內(nèi)存, 而不是虛擬機的堆內(nèi)存中,所以不會因為圖片加載而導致oom, 同時也減少垃圾回收器頻繁調(diào)用回收Bitmap導致的界面卡頓,性能更高.

② 漸進式加載JPEG圖片, 支持圖片從模糊到清晰加載

③ 圖片可以以任意的中心點顯示在ImageView, 而不僅僅是圖片的中心.

④ JPEG圖片改變大小也是在native進行的, 不是在虛擬機的堆內(nèi)存, 同樣減少OOM

⑤ 很好的支持GIF圖片的顯示

缺點:

框架較大, 影響Apk體積,使用較繁瑣

17.網(wǎng)絡框架有哪些?他們之間的區(qū)別是什么?(這個也會問到)

Xutils

這個框架非常全面,可以進行網(wǎng)絡請求,可以進行圖片加載處理,可以數(shù)據(jù)儲存,還可以對view進行注解,使用這個框架非常方便,但是缺點也是非常明顯的,使用這個項目,會導致項目對這個框架依賴非常的嚴重,一旦這個框架出現(xiàn)問題,那么對項目來說影響非常大的

OKhttp

Android開發(fā)中是可以直接使用現(xiàn)成的api進行網(wǎng)絡請求的。就是使用HttpClient,HttpUrlConnection進行操作。okhttp針對Java和Android程序,封裝的一個高性能的http請求庫,支持同步,異步,而且okhttp又封裝了線程池,封裝了數(shù)據(jù)轉換,封裝了參數(shù)的使用,錯誤處理等。API使用起來更加的方便。但是我們在項目中使用的時候仍然需要自己在做一層封裝,這樣才能使用的更加的順手。

Volley

Volley是Google官方出的一套小而巧的異步請求庫,該框架封裝的擴展性很強,支持HttpClient、HttpUrlConnection, 甚至支持OkHttp,而且Volley里面也封裝了ImageLoader,所以如果你愿意你甚至不需要使用圖片加載框架,不過這塊功能沒有一些專門的圖片加載框架強大,對于簡單的需求可以使用,稍復雜點的需求還是需要用到專門的圖片加載框架。Volley也有缺陷,比如不支持post大數(shù)據(jù),所以不適合上傳文件。不過Volley設計的初衷本身也就是為頻繁的、數(shù)據(jù)量小的網(wǎng)絡請求而生。

Retrofit

Retrofit是Square公司出品的默認基于OkHttp封裝的一套RESTful網(wǎng)絡請求框架,RESTful是目前流行的一套api設計的風格, 并不是標準。Retrofit的封裝可以說是很強大,里面涉及到一堆的設計模式,可以通過注解直接配置請求,可以使用不同的http客戶端,雖然默認是用http ,可以使用不同Json Converter 來序列化數(shù)據(jù),同時提供對RxJava的支持,使用Retrofit + OkHttp + RxJava + Dagger2 可以說是目前比較潮的一套框架,但是需要有比較高的門檻。

Volley VS OkHttp

Volley的優(yōu)勢在于封裝的更好,而使用OkHttp你需要有足夠的能力再進行一次封裝。而OkHttp的優(yōu)勢在于性能更高,因為 OkHttp基于NIO和Okio ,所以性能上要比 Volley更快。IO 和 NIO這兩個都是Java中的概念,如果我從硬盤讀取數(shù)據(jù),第一種方式就是程序一直等,數(shù)據(jù)讀完后才能繼續(xù)操作這種是最簡單的也叫阻塞式IO,還有一種是你讀你的,程序接著往下執(zhí)行,等數(shù)據(jù)處理完你再來通知我,然后再處理回調(diào)。而第二種就是 NIO 的方式,非阻塞式, 所以NIO當然要比IO的性能要好了,而 Okio是 Square 公司基于IO和NIO基礎上做的一個更簡單、高效處理數(shù)據(jù)流的一個庫。理論上如果Volley和OkHttp對比的話,更傾向于使用 Volley,因為Volley內(nèi)部同樣支持使用OkHttp,這點OkHttp的性能優(yōu)勢就沒了, 而且 Volley 本身封裝的也更易用,擴展性更好些。

OkHttp VS Retrofit

毫無疑問,Retrofit 默認是基于 OkHttp 而做的封裝,這點來說沒有可比性,肯定首選 Retrofit。

Volley VS Retrofit

這兩個庫都做了不錯的封裝,但Retrofit解耦的更徹底,尤其Retrofit2.0出來,Jake對之前1.0設計不合理的地方做了大量重構, 職責更細分,而且Retrofit默認使用OkHttp,性能上也要比Volley占優(yōu)勢,再有如果你的項目如果采用了RxJava ,那更該使用 Retrofit 。所以這兩個庫相比,Retrofit更有優(yōu)勢,在能掌握兩個框架的前提下該優(yōu)先使用 Retrofit。但是Retrofit門檻要比Volley稍高些,要理解他的原理,各種用法,想徹底搞明白還是需要花些功夫的,如果你對它一知半解,那還是建議在商業(yè)項目使用Volley吧。

18.熟悉哪些設計模式?

按照自己的實際情況回答,當然是越多越好。比如我自己也就熟悉個單例模式。

19.三級緩存(這個偶爾會問)

網(wǎng)絡加載,不優(yōu)先加載,速度慢,浪費流量

本地緩存,次優(yōu)先加載,速度快

內(nèi)存緩存,優(yōu)先加載,速度最快

首次加載Android App時,肯定要通過網(wǎng)絡交互來獲取圖片,之后我們可以將圖片保存至本地SD卡和內(nèi)存中,之后運行APP時,優(yōu)先訪問內(nèi)存中的圖片緩存,若內(nèi)存中沒有,則加載本地SD卡中圖片,最后選擇訪問網(wǎng)絡

20.Android與服務器交互的方式中的對稱加密和非對稱加密是什么?

對稱加密,就是加密和解密數(shù)據(jù)都是使用同一個key,這方面的算法有DES。

非對稱加密,加密和解密是使用不同的key。發(fā)送數(shù)據(jù)之前要先和服務端約定生成公鑰和私鑰,使用公鑰加密的數(shù)據(jù)可以用私鑰解密,反之。這方面的算法有RSA。ssh 和 ssl都是典型的非對稱加密。

往期文章

十面阿里,七面頭條

在百人團隊參與游戲研發(fā)體驗

除了敲代碼,你還有什么副業(yè)嗎?

面試官:你分析過線程池源碼嗎?

淺談final、finally、finalize有什么不同?

文章版權歸作者所有,未經(jīng)允許請勿轉載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。

轉載請注明本文地址:http://systransis.cn/yun/77822.html

相關文章

  • 金三銀四,2019大廠Android高級工程師面試整理

    摘要:原文地址游客前言金三銀四,很多同學心里大概都準備著年后找工作或者跳槽。最近有很多同學都在交流群里求大廠面試題。 最近整理了一波面試題,包括安卓JAVA方面的,目前大廠還是以安卓源碼,算法,以及數(shù)據(jù)結構為主,有一些中小型公司也會問到混合開發(fā)的知識,至于我為什么傾向于混合開發(fā),我的一句話就是走上編程之路,將來你要學不僅僅是這些,豐富自己方能與世接軌,做好全棧的裝備。 原文地址:游客kutd...

    tracymac7 評論0 收藏0
  • Android-Java面試

    摘要:好不容易在月號這天中午點左右接到了來自阿里的面試電話。這里會不斷收集和更新基礎相關的面試題,目前已收集題。面試重難點的和的打包過程多線程機制機制系統(tǒng)啟動過程,啟動過程等等掃清面試障礙最新面試經(jīng)驗分享,此為第一篇,開篇。 2016 年末,騰訊,百度,華為,搜狗和滴滴面試題匯總 2016 年未,騰訊,百度,華為,搜狗和滴滴面試題匯總 各大公司 Java 后端開發(fā)面試題總結 各大公司 Jav...

    TalkingData 評論0 收藏0

發(fā)表評論

0條評論

最新活動
閱讀需要支付1元查看
<