安卓面試題及答案(二)

44. 請介紹下ContentProvider是如何實現數據共享的。創建一個屬於你自己的Content provider或者將你的數據添加到一個已經存在的Contentprovider中,前提是有相同數據類型並且有寫入Content provider的權限。
  45. 如何啓用Service,如何停用Service。Android中的service類似於windows中的service,service一般沒有用戶操作界面,它運行於系統中不容易被用戶發覺,
  可以使用它開發如監控之類的程序。
  一。步驟
  第一步:繼承Service類
  public class SMSService extends Service { }
  第二步:在AndroidManifest.xml文件中的節點裏對服務進行配置:
  二。Context.startService()和Context.bindService
  服務不能自己運行,需要通過調用Context.startService()或Context.bindService()方法啓動服務。這兩個方法都可
  以啓動Service,但是它們的使用場合有所不同。
  1.使用startService()方法啓用服務,調用者與服務之間沒有關連,即使調用者退出了,服務仍然運行。
  使用bindService()方法啓用服務,調用者與服務綁定在了一起,調用者一旦退出,服務也就終止。
  2.採用Context.startService()方法啓動服務,在服務未被創建時,系統會先調用服務的onCreate()方法,
  接着調用onStart()方法。如果調用startService()方法前服務已經被創建,多次調用startService()方法並
  不會導致多次創建服務,但會導致多次調用onStart()方法。
  採用startService()方法啓動的服務,只能調用Context.stopService()方法結束服務,服務結束時會調用
  onDestroy()方法。
  3.採用Context.bindService()方法啓動服務,在服務未被創建時,系統會先調用服務的onCreate()方法,
  接着調用onBind()方法。這個時候調用者和服務綁定在一起,調用者退出了,系統就會先調用服務的onUnbind()方法,
  。接着調用onDestroy()方法。如果調用bindService()方法前服務已經被綁定,多次調用bindService()方法並不會
  導致多次創建服務及綁定(也就是說onCreate()和onBind()方法並不會被多次調用)。如果調用者希望與正在綁定的服務
  解除綁定,可以調用unbindService()方法,調用該方法也會導致系統調用服務的onUnbind()-->onDestroy()方法。
  三。Service的生命週期
  1.Service常用生命週期回調方法如下:
  onCreate() 該方法在服務被創建時調用,該方法只會被調用一次,無論調用多少次startService()或bindService()方法,
  服務也只被創建一次。 onDestroy()該方法在服務被終止時調用。
  2. Context.startService()啓動Service有關的生命週期方法
  onStart() 只有採用Context.startService()方法啓動服務時纔會回調該方法。該方法在服務開始運行時被調用。
  多次調用startService()方法儘管不會多次創建服務,但onStart()方法會被多次調用。
  3. Context.bindService()啓動Service有關的生命週期方法
  onBind()只有採用Context.bindService()方法啓動服務時纔會回調該方法。該方法在調用者與服務綁定時被調用,
  當調用者與服務已經綁定,多次調用Context.bindService()方法並不會導致該方法被多次調用。
  onUnbind()只有採用Context.bindService()方法啓動服務時纔會回調該方法。該方法在調用者與服務解除綁定時被調用。
  備註:
  1. 採用startService()啓動服務
  Intent intent =new Intent(DemoActivity.this, DemoService.class);
  startService(intent);
  2.Context.bindService()啓動
  Intent intent =new Intent(DemoActivity.this, DemoService.class);
  bindService(intent, conn, Context.BIND_AUTO_CREATE);
  //unbindService(conn);//解除綁定
  46. 註冊廣播有幾種方式,這些方式有何優缺點?請談談Android引入廣播機制的用意。 Android廣播機制(兩種註冊方法)
  在android下,要想接受廣播信息,那麼這個廣播接收器就得我們自己來實現了,我們可以繼承BroadcastReceiver,就可以有一個廣播接受器了。有個接受器還不夠,我們還得重寫BroadcastReceiver裏面的onReceiver方法,當來廣播的時候我們要幹什麼,這就要我們自己來實現,不過我們可以搞一個信息防火牆。具體的代碼:
  public class SmsBroadCastReceiverextends BroadcastReceiver
  {
  @Override
  public void onReceive(Context context, Intent intent)
  {
  Bundle bundle = intent.getExtras();
  Object[] object = (Object[])bundle.get("pdus");
  SmsMessage sms[]=new SmsMessage[object.length];
  for(int i=0;i
  {
  sms[0] =SmsMessage.createFromPdu((byte[])object);
  Toast.makeText(context, "來自"+sms.getDisplayOriginatingAddress()+"的消息是:"+sms.getDisplayMessageBody(),Toast.LENGTH_SHORT).show();
  }
  //終止廣播,在這裏我們可以稍微處理,根據用戶輸入的號碼可以實現短信防火牆。
  abortBroadcast();
  }
  }
  當實現了廣播接收器,還要設置廣播接收器接收廣播信息的類型,這裏是信息:android.provider.Telephony.SMS_RECEIVED
  我們就可以把廣播接收器註冊到系統裏面,可以讓系統知道我們有個廣播接收器。這裏有兩種,一種是代碼動態註冊:
  //生成廣播處理
  smsBroadCastReceiver = newSmsBroadCastReceiver();
  //實例化過濾器並設置要過濾的廣播
  IntentFilter intentFilter = newIntentFilter("android.provider.Telephony.SMS_RECEIVED");
  //註冊廣播
  BroadCastReceiverActivity.this.registerReceiver(smsBroadCastReceiver,intentFilter);
  一種是在AndroidManifest.xml中配置廣播
  package="spl.broadCastReceiver"
  android:versionCode="1"
  android:versionName="1.0">
  android:label="@string/app_name">
  兩種註冊類型的區別是:
  1)第一種不是常駐型廣播,也就是說廣播跟隨程序的生命週期。
  2)第二種是常駐型,也就是說當應用程序關閉後,如果有信息廣播來,程序也會被系統調用自動運行。
  47. 請解釋下在單線程模型中Message、Handler、MessageQueue、Looper之間的關係。Handler簡介:
  一個Handler允許你發送和處理Message和Runable對象,這些對象和一個線程的MessageQueue相關聯。每一個線程實例和一個單獨的線程以及該線程的MessageQueue相關聯。當你創建一個新的Handler時,它就和創建它的線程綁定在一起了。這裏,線程我們也可以理解爲線程的MessageQueue。從這一點上來看,Handler把Message和Runable對象傳遞給MessageQueue,而且在這些對象離開MessageQueue時,Handler負責執行他們。
  Handler有兩個主要的用途:(1)確定在將來的某個時間點執行一個或者一些Message和Runnable對象。(2)在其他線程(不是Handler綁定線程)中排入一些要執行的動作。
  Scheduling Message,即(1),可以通過以下方法完成:
  post(Runnable):Runnable在handler綁定的線程上執行,也就是說不創建新線程。
  postAtTime(Runnable,long):
  postDelayed(Runnable,long):
  sendEmptyMessage(int):
  sendMessage(Message):
  sendMessageAtTime(Message,long):
  sendMessageDelayed(Message,long):
  post這個動作讓你把Runnable對象排入MessageQueue,MessageQueue受到這些消息的時候執行他們,當然以一定的排序。sendMessage這個動作允許你把Message對象排成隊列,這些Message對象包含一些信息,Handler的hanlerMessage(Message)會處理這些Message.當然,handlerMessage(Message)必須由Handler的子類來重寫。這是編程人員需要作的事。
  當posting或者sending到一個Hanler時,你可以有三種行爲:當MessageQueue準備好就處理,定義一個延遲時間,定義一個精確的時間去處理。後兩者允許你實現timeout,tick,和基於時間的行爲。
  當你的應用創建一個新的進程時,主線程(也就是UI線程)自帶一個MessageQueue,這個MessageQueue管理頂層的應用對象(像activities,broadcast receivers等)和主線程創建的窗體。你可以創建自己的線程,並通過一個Handler和主線程進行通信。這和之前一樣,通過post和sendmessage來完成,差別在於在哪一個線程中執行這麼方法。在恰當的時候,給定的Runnable和Message將在Handler的MessageQueue中被Scheduled。
  Message簡介:
  Message類就是定義了一個信息,這個信息中包含一個描述符和任意的數據對象,這個信息被用來傳遞給Handler.Message對象提供額外的兩個int域和一個Object域,這可以讓你在大多數情況下不用作分配的動作。
  儘管Message的構造函數是public的,但是獲取Message實例的最好方法是調用Message.obtain(),或者Handler.obtainMessage()方法,這些方法會從回收對象池中獲取一個。
  MessageQueue簡介:
  這是一個包含message列表的底層類。Looper負責分發這些message。Messages並不是直接加到一個MessageQueue中,而是通過MessageQueue.IdleHandler關聯到Looper。
  你可以通過Looper.myQueue()從當前線程中獲取MessageQueue。
  Looper簡介:
  Looper類被用來執行一個線程中的message循環。默認情況,沒有一個消息循環關聯到線程。在線程中調用prepare()創建一個Looper,然後用loop()來處理messages,直到循環終止。
  大多數和message loop的交互是通過Handler。
  下面是一個典型的帶有Looper的線程實現。
  class LooperThread extends Thread {
  public Handler mHandler;
  public void run() {
  Looper.prepare();
  mHandler = new Handler() {
  public voidhandleMessage(Message msg) {
  // process incomingmessages here
  }
  };
  Looper.loop();
  }
  }
  48. AIDL的全稱是什麼?如何工作?能處理哪些類型的數據?AIDL的英文全稱是Android Interface Define Language
  當A進程要去調用B進程中的service時,並實現通信,我們通常都是通過AIDL來操作的
  A工程:
  首先我們在net.blogjava.mobile.aidlservice包中創建一個RemoteService.aidl文件,在裏面我們自定義一個接口,含有方法get。ADT插件會在gen目錄下自動生成一個RemoteService.java文件,該類中含有一個名爲RemoteService.stub的內部類,該內部類中含有aidl文件接口的get方法。
  說明一:aidl文件的位置不固定,可以任意
  然後定義自己的MyService類,在MyService類中自定義一個內部類去繼承RemoteService.stub這個內部類,實現get方法。在onBind方法中返回這個內部類的對象,系統會自動將這個對象封裝成IBinder對象,傳遞給他的調用者。
  其次需要在AndroidManifest.xml文件中配置MyService類,代碼如下:
  爲什麼要指定調用AIDL服務的ID,就是要告訴外界MyService這個類能夠被別的進程訪問,只要別的進程知道這個ID,正是有了這個ID,B工程才能找到A工程實現通信。
  說明:AIDL並不需要權限
  B工程:
  首先我們要將A工程中生成的RemoteService.java文件拷貝到B工程中,在bindService方法中綁定aidl服務
  綁定AIDL服務就是將RemoteService的ID作爲intent的action參數。
  說明:如果我們單獨將RemoteService.aidl文件放在一個包裏,那個在我們將gen目錄下的該包拷貝到B工程中。如果我們將RemoteService.aidl文件和我們的其他類存放在一起,那麼我們在B工程中就要建立相應的包,以保證RmoteService.java文件的報名正確,我們不能修改RemoteService.java文件
  bindService(newInten("net.blogjava.mobile.aidlservice.RemoteService"),serviceConnection, Context.BIND_AUTO_CREATE);
  ServiceConnection的onServiceConnected(ComponentName name, IBinderservice)方法中的service參數就是A工程中MyService類中繼承了RemoteService.stub類的內部類的對象。
  49. 請解釋下Android程序運行時權限與文件系統權限的區別。運行時權限Dalvik( android授權)
  文件系統 linux 內核授權
  50. 系統上安裝了多種瀏覽器,能否指定某瀏覽器訪問指定頁面?請說明原由。通過直接發送Uri把參數帶過去,或者通過manifest裏的intentfilter裏的data屬性
  51. 你如何評價Android系統?優缺點。答:Android平臺手機 5大優勢:
  一、開放性
  在優勢方面,Android平臺首先就是其開發性,開發的平臺允許任何移動終端廠商加入到Android聯盟中來。顯著的開放性可以使其擁有更多的開發者,隨着用戶和應用的日益豐富,一個嶄新的平臺也將很快走向成熟。開放性對於Android的發展而言,有利於積累人氣,這裏的人氣包括消費者和廠商,而對於消費者來講,隨大的受益正是豐富的軟件資源。開放的平臺也會帶來更大競爭,如此一來,消費者將可以用更低的價位購得心儀的手機。
  二、掙脫運營商的束縛
  在過去很長的一段時間,特別是在歐美地區,手機應用往往受到運營商制約,使用什麼功能接入什麼網絡,幾乎都受到運營商的控制。從去年iPhone 上市 ,用戶可以更加方便地連接網絡,運營商的制約減少。隨着EDGE、HSDPA這些2G至3G移動網絡的逐步過渡和提升,手機隨意接入網絡已不是運營商口中的笑談,當你可以通過手機IM軟件方便地進行即時聊天時,再回想不久前天價的彩信和圖鈴下載業務,是不是像噩夢一樣?互聯網巨頭Google推動的Android終端天生就有網絡特色,將讓用戶離互聯網更近。
  三、豐富的硬件選擇
  這一點還是與Android平臺的開放性相關,由於Android的開放性,衆多的廠商會推出千奇百怪,功能特色各具的多種產品。功能上的差異和特色,卻不會影響到數據同步、甚至軟件的兼容,好比你從諾基亞 Symbian風格手機 一下改用蘋果 iPhone ,同時還可將Symbian中優秀的軟件帶到iPhone上使用、聯繫人等資料更是可以方便地轉移,是不是非常方便呢?
  四、不受任何限制的開發商
  Android平臺提供給第三方開發商一個十分寬泛、自由的環境,不會受到各種條條框框的阻擾,可想而知,會有多少新穎別緻的軟件會誕生。但也有其兩面性,血腥、暴力、情色方面的程序和遊戲如可控制正是留給Android難題之一。
  五、無縫結合的Google應用
  如今叱詫互聯網的Google已經走過10年度歷史,從搜索巨人到全面的互聯網滲透,Google服務如地圖、郵件、搜索等已經成爲連接用戶和互聯網的重要紐帶,而Android平臺手機將無縫結合這些優秀的Google服務。
  再說Android的5大不足:
  一、安全和隱私
  由於手機與互聯網的緊密聯繫,個人隱私很難得到保守。除了上網過程中經意或不經意留下的個人足跡,Google這個巨人也時時站在你的身後,洞穿一切,因此,互聯網的深入將會帶來新一輪的隱私危機。
  二、首先開賣Android手機的不是最大運營商
  衆所周知,T-Mobile在23日,於美國紐約發佈 了Android首款手機G1。但是在北美市場,最大的兩家運營商乃AT&T和Verizon,而目前所知取得Android手機銷售權的僅有 T-Mobile和Sprint,其中T-Mobile的3G網絡相對於其他三家也要遜色不少,因此,用戶可以買賬購買G1,能否體驗到最佳的3G網絡服務則要另當別論了!
  三、運營商仍然能夠影響到Android手機
  在國內市場,不少用戶對購得移動定製機不滿,感覺所購的手機被人塗畫了廣告一般。這樣的情況在國外市場同樣出現。Android手機的另一發售運營商Sprint就將在其機型中內置其手機商店程序。
  四、同類機型用戶減少
  在不少手機論壇都會有針對某一型號的子論壇,對一款手機的使用心得交流,並分享軟件資源。而對於Android平臺手機,由於廠商豐富,產品類型多樣,這樣使用同一款機型的用戶越來越少,缺少統一機型的程序強化。舉個稍顯不當的例子,現在山寨機氾濫,品種各異,就很少有專門針對某個型號山寨機的討論和羣組,除了哪些功能異常搶眼、頗受追捧的機型以外。
  五、過分依賴開發商缺少標準配置
  在使用PC端的Windows Xp系統的時候,都會內置微軟Windows Media Player這樣一個瀏覽器程序,用戶可以選擇更多樣的播放器,如Realplay或暴風影音等。但入手開始使用默認的程序同樣可以應付多樣的需要。在Android平臺中,由於其開放性,軟件更多依賴第三方廠商,比如Android系統的SDK中就沒有內置音樂 播放器,全部依賴第三方開發,缺少了產品的統一性。
  52. 什麼是ANR 如何避免它?
  答:ANR:Application NotResponding,五秒
  在Android中,活動管理器和窗口管理器這兩個系統服務負責監視應用程序的響應。當出現下列情況時,Android就會顯示ANR對話框了:
  對輸入事件(如按鍵、觸摸屏事件)的響應超過5秒
  意向接受器(intentReceiver)超過10秒鐘仍未執行完畢
  Android應用程序完全運行在一個獨立的線程中(例如main)。這就意味着,任何在主線程中運行的,需要消耗大量時間的操作都會引發ANR。因爲此時,你的應用程序已經沒有機會去響應輸入事件和意向廣播(Intentbroadcast)。
  因此,任何運行在主線程中的方法,都要儘可能的只做少量的工作。特別是活動生命週期中的重要方法如onCreate()和 onResume()等更應如此。潛在的比較耗時的操作,如訪問網絡和數據庫;或者是開銷很大的計算,比如改變位圖的大小,需要在一個單獨的子線程中完成(或者是使用異步請求,如數據庫操作)。但這並不意味着你的主線程需要進入阻塞狀態已等待子線程結束 -- 也不需要調用Therad.wait()或者Thread.sleep()方法。取而代之的是,主線程爲子線程提供一個句柄(Handler),讓子線程在即將結束的時候調用它(xing:可以參看Snake的例子,這種方法與以前我們所接觸的有所不同)。使用這種方法涉及你的應用程序,能夠保證你的程序對輸入保持良好的響應,從而避免因爲輸入事件超過5秒鐘不被處理而產生的ANR。這種實踐需要應用到所有顯示用戶界面的線程,因爲他們都面臨着同樣的超時問題。
  53. 什麼情況會導致Force Close ?如何避免?能否捕獲導致其的異常?
  答:一般像空指針啊,可以看起logcat,然後對應到程序中 來解決錯誤
  54. Android本身的api並未聲明會拋出異常,則其在運行時有無可能拋出runtime異常,你遇到過嗎?諾有的話會導致什麼問題?如何解決?
  55. 簡要解釋一下activity、 intent 、intent filter、service、Broadcase、BroadcaseReceiver
  答:一個activity呈現了一個用戶可以操作的可視化用戶界面
  一個service不包含可見的用戶界面,而是在後臺無限地運行
  可以連接到一個正在運行的服務中,連接後,可以通過服務中暴露出來的藉口與其進行通信
  一個broadcast receiver是一個接收廣播消息並作出迴應的component,broadcastreceiver沒有界面
  intent:content provider在接收到ContentResolver的請求時被激活。
  activity, service和broadcast receiver是被稱爲intents的異步消息激活的。
  一個intent是一個Intent對象,它保存了消息的內容。對於activity和service來說,它指定了請求的操作名稱和待操作數據的URI
  Intent對象可以顯式的指定一個目標component。如果這樣的話,android會找到這個component(基於manifest文件中的聲明)並激活它。但如果一個目標不是顯式指定的,android必須找到響應intent的最佳component。
  它是通過將Intent對象和目標的intent filter相比較來完成這一工作的。一個component的intent filter告訴android該component能處理的intent。intent filter也是在manifest文件中聲明的。
  56.  IntentService有何優點?
  答:IntentService 的好處
  * Acitivity的進程,當處理Intent的時候,會產生一個對應的Service
  * Android的進程處理器現在會盡可能的不kill掉你
  * 非常容易使用
  57. 橫豎屏切換時候activity的生命週期?
  1、不設置Activity的android:configChanges時,切屏會重新調用各個生命週期,切橫屏時會執行一次,切豎屏時會執行兩次
  2、設置Activity的android:configChanges="orientation"時,切屏還是會重新調用各個生命週期,切橫、豎屏時只會執行一次
  3、設置Activity的android:configChanges="orientation|keyboardHidden"時,切屏不會重新調用各個生命週期,只會執行onConfigurationChanged方法
  如何將SQLite數據庫(dictionary.db文件)與apk文件一起發佈?
  解答:可以將dictionary.db文件複製到Eclipse Android工程中的res aw目錄中。所有在res aw目錄中的文件不會被壓縮,這樣可以直接提取該目錄中的文件。可以將dictionary.db文件複製到res aw目錄中
  58. 如何將打開res aw目錄中的數據庫文件?
  解答:在Android中不能直接打開res aw目錄中的數據庫文件,而需要在程序第一次啓動時將該文件複製到手機內存或SD卡的某個目錄中,然後再打開該數據庫文件。複製的基本方法是使用getResources().openRawResource方法獲得res aw目錄中資源的 InputStream對象,然後將該InputStream對象中的數據寫入其他的目錄中相應文件中。在Android SDK中可以使用SQLiteDatabase.openOrCreateDatabase方法來打開任意目錄中的SQLite數據庫文件。
  59. Android引入廣播機制的用意?
  答:a:從MVC的角度考慮(應用程序內)
  其實回答這個問題的時候還可以這樣問,android爲什麼要有那4大組件,現在的移動開發模型基本上也是照搬的web那一套MVC架構,只不過是改了點嫁妝而已。android的四大組件本質上就是爲了實現移動或者說嵌入式設備上的MVC架構,它們之間有時候是一種相互依存的關係,有時候又是一種補充關係,引入廣播機制可以方便幾大組件的信息和數據交互。
  b:程序間互通消息(例如在自己的應用程序內監聽系統來電)
  c:效率上(參考UDP的廣播協議在局域網的方便性)
  d:設計模式上(反轉控制的一種應用,類似監聽者模式)
  60. Android dvm的進程和Linux的進程, 應用程序的進程是否爲同一個概念
  DVM指dalivk的虛擬機。每一個Android應用程序都在它自己的進程中運行,都擁有一個獨立的Dalvik虛擬機實例。而每一個DVM都是在Linux 中的一個進程,所以說可以認爲是同一個概念。
  61. sim卡的EF 文件有何作用
  sim卡的文件系統有自己規範,主要是爲了和手機通訊,sim本 身可以有自己的操作系統,EF就是作存儲並和手機通訊用的
  62. 嵌入式操作系統內存管理有哪幾種, 各有何特性
  頁式,段式,段頁,用到了MMU,虛擬空間等技術
  63. 什麼是嵌入式實時操作系統, Android 操作系統屬於實時操作系統嗎?
  嵌入式實時操作系統是指當外界事件或數據產生時,能夠接受並以足夠快的速度予以處理,其處理的結果又能在規定的時間之內來控制生產過程或對處理系統作出快速響應,並控制所有實時任務協調一致運行的嵌入式操作系統。主要用於工業控制、 軍事設備、 航空航天等領域對系統的響應時間有苛刻的要求,這就需要使用實時系統。又可分爲軟實時和硬實時兩種,而android是基於linux內核的,因此屬於軟實時。
  64. 一條最長的短信息約佔多少byte?
  中文70(包括標點),英文160,160個字節。
  65. android中的動畫有哪幾類,它們的特點和區別是什麼?
  兩種,一種是Tween動畫、還有一種是Frame動畫。Tween動畫,這種實現方式可以使視圖組件移動、放大、縮小以及產生透明度的變化;另一種Frame動畫,傳統的動畫方法,通過順序的播放排列好的圖片來實現,類似電影。
  66. handler機制的原理
  andriod提供了Handler 和 Looper 來滿足線程間的通信。Handler先進先出原則。Looper類用來管理特定線程內對象之間的消息交換(MessageExchange)。
  1)Looper: 一個線程可以產生一個Looper對象,由它來管理此線程裏的MessageQueue(消息隊列)。
  2)Handler: 你可以構造Handler對象來與Looper溝通,以便push新消息到MessageQueue裏;或者接收Looper從Message Queue取出)所送來的消息。
  3) Message Queue(消息隊列):用來存放線程放入的消息。
  4)線程:UIthread 通常就是main thread,而Android啓動程序時會替它建立一個MessageQueue。
  67. 說說mvc模式的原理,它在android中的運用
  MVC(Model_view_contraller)”模型_視圖_控制器”。 MVC應用程序總是由這三個部分組成。Event(事件)導致Controller改變Model或View,或者同時改變兩者。只要Controller改變了Models的數據或者屬性,所有依賴的View都會自動更新。類似的,只要Contro
  68. DDMS和TraceView的區別? DDMS是一個程序執行查看器,在裏面可以看見線程和堆棧等信息,TraceView是程序性能分析器 。
  69. java中如何引用本地語言 可以用JNI(java nativeinterface java 本地接口)接口。
  70. 談談Android的IPC(進程間通信)機制 IPC是內部進程通信的簡稱, 是共享"命名管道"的資源。Android中的IPC機制是爲了讓Activity和Service之間可以隨時的進行交互,故在Android中該機制,只適用於Activity和Service之間的通信,類似於遠程方法調用,類似於C/S模式的訪問。通過定義AIDL接口文件來定義IPC接口。Servier端實現IPC接口,Client端調用IPC接口本地代理。
  71. NDK是什麼NDK是一些列工具的集合,NDK提供了一系列的工具,幫助開發者迅速的開發C/C++的動態庫,並能自動將so和java 應用打成apk包。
  NDK集成了交叉編譯器,並提供了相應的mk文件和隔離cpu、平臺等的差異,開發人員只需簡單的修改mk文件就可以創建出so






1.android dvm 的進程和Linux的進程,應用程序的進程是否爲同一個概念:


答:dvm是dalivk虛擬機。每一個android應用程序都在自己的進程中運行,都擁有一個dalivk虛擬機實例。而每一個dvm都是在linux的一個進程。所以說可以認爲是同一個概念。


2.android的動畫有哪幾種?他們的特點和區別是什麼?


答:兩種,一種是tween動畫,一種是frame動畫。tween動畫,這種實現方式可以使視圖組件移動,放大或縮小以及產生透明度的變化。frame動畫,傳統的動畫方法,通過順序的播放排列好的圖片來實現,類似電影。


3.handler進制的原理:


答:android提供了handler和looper來滿足線程間的通信。Handler先進先出原則。looper用來管理特定線程內對象之間的消息交換(message Exchange).


    1)looper:一個線程可以產生一個looper對象,由它來管理此線程裏的message queue(消息隊列)


   2)handler:你可以構造一個handler對象來與looper溝通,以便push新消息到messagequeue裏;或者接收looper(從messagequeue裏取出)所送來的消息。


    3)messagequeue:用來存放線程放入的消息。


    4)線程:UI thread 通常就是main thread,而android啓動程序時會爲它建立一個message queue.


4.android view的刷新:


答:Android中對View的更新有很多種方式,使用時要區分不同的應用場合。我感覺最要緊的是分清:多線程和雙緩衝的使用情況。


    1).不使用多線程和雙緩衝


   這種情況最簡單了,一般只是希望在View發生改變時對UI進行重繪。你只需在Activity中顯式地調用View對象中的invalidate()方法即可。系統會自動調用 View的onDraw()方法。


    2).使用多線程和不使用雙緩衝


    這種情況需要開啓新的線程,新開的線程就不好訪問View對象了。強行訪問的話會報:android.view.ViewRoot$CalledFromWrongThreadException:Only the originalthread that created a view hierarchy can touch its views.


    這時候你需要創建一個繼承了android.os.Handler的子類,並重寫handleMessage(Messagemsg)方法。android.os.Handler是能發送和處理消息的,你需要在Activity中發出更新UI的消息,然後再你的Handler(可以使用匿名內部類)中處理消息(因爲匿名內部類可以訪問父類變量,你可以直接調用View對象中的invalidate()方法 )。也就是說:在新線程創建併發送一個Message,然後再主線程中捕獲、處理該消息。


    3).使用多線程和雙緩衝


    Android中SurfaceView是View的子類,她同時也實現了雙緩衝。你可以定義一個她的子類並實現SurfaceHolder.Callback接口。由於實現SurfaceHolder.Callback接口,新線程就不需要android.os.Handler幫忙了。SurfaceHolder中lockCanvas()方法可以鎖定畫布,繪製玩新的圖像後調用unlockCanvasAndPost(canvas)解鎖(顯示),還是比較方便得。


 


5.說說mvc模式的原理,它在android中的運用:


答:android的官方建議應用程序的開發採用mvc模式。何謂mvc?


 


 mvc是model,view,controller的縮寫,mvc包含三個部分:


 


  l模型(model)對象:是應用程序的主體部分,所有的業務邏輯都應該寫在該層。


  2視圖(view)對象:是應用程序中負責生成用戶界面的部分。也是在整個mvc架構中用戶唯一可以看到的一層,接收用戶的輸入,顯示處理結果。


  3控制器(control)對象:是根據用戶的輸入,控制用戶界面數據顯示及更新model對象狀態的部分,控制器更重要的一種導航功能,想用用戶出發的相關事件,交給m哦得了處理。


 


 android鼓勵弱耦合和組件的重用,在android中mvc的具體體現如下:


    1)視圖層(view):一般採用xml文件進行界面的描述,使用的時候可以非常方便的引入,當然,如何你對android瞭解的比較的多了話,就一定 可以想到在android中也可以使用javascript+html等的方式作爲view層,當然這裏需要進行java和javascript之間的通 信,幸運的是,android提供了它們之間非常方便的通信實現。


 2)控制層(controller):android的控制層的重 任通常落在了衆多的acitvity的肩上,這句話也就暗含了不要在acitivity中寫代碼,要通過activity交割model業務邏輯層處理, 這樣做的另外一個原因是android中的acitivity的響應時間是5s,如果耗時的操作放在這裏,程序就很容易被回收掉。


 3)模型層(model):對數據庫的操作、對網絡等的操作都應該在model裏面處理,當然對業務計算等操作也是必須放在的該層的。


 


6.Activity的生命週期:


答:onCreate: 在這裏創建界面,做一些數據 的初始化工作


 


  onStart: 到這一步變成用戶可見不可交互的


    onResume:變成和用戶可交互 的,(在activity 棧系統通過棧的方式管理這些個Activity的最上面,運行完彈出棧,則回到上一個Activity)


  onPause: 到這一步是可見但不可交互的,系統會停止動畫 等消耗CPU 的事情從上文的描述已經知道,應該在這裏保存你的一些數據,因爲這個時候你的程序的優先級降低,有可能被系統收回。在這裏保存的數據,應該在


  onstop: 變得不可見,被下一個activity覆蓋了


onDestroy: 這是activity被幹掉前最後一個被調用方法了,可能是外面類調用finish方法或者是系統爲了節省空間將它暫時性的幹掉
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章