站長資訊網
        最全最豐富的資訊網站

        Android開發者面試阿里等大廠遇到的問題整理

        推薦:《2020年Android面試題大匯總【收藏】》

        先簡單說說我這四年期間的面試經歷吧。面試的公司很多,其中有讓我心血沸騰的經歷,也有讓我感到失望到無助的經歷,我將這些體會都記錄下來,細想之后很值得,面了這么多公司,要是最后什么也沒有留下來,那就太浪費了。至少對于我來說有些東西在整理總結之后才能得到一個肯定的答案。希望這些能對即將換工作或者打算看看機會的你有一些幫助。

        以下問題的答案均是個人四年來多次面試實踐中整理的,如有不同意見,歡迎斧正。

        1.自定義Handler時如何避免內存泄漏

        答案:

        一般非靜態內部類持有外部類的引用的情況下,造成外部類在使用完成后不能被系統回收內存,從而造成內存泄漏。為了避免這個問題,我們可以自定義的Handler聲明為靜態內部類形式,然后通過弱引用的方式,讓Handler持有外部類的引用,從而可避免內存泄漏問題。

        以下是代碼實現

        public class MainActivity extends AppCompatActivity { private static final String TAG = "MainActivity"; private TextView mTextView; private WeakReference<MainActivity> activityWeakReference; private MyHandler myHandler;  static class MyHandler extends Handler {     private MainActivity activity;      MyHandler(WeakReference<MainActivity> ref) {         this.activity = ref.get();     }      @Override     public void handleMessage(Message msg) {         super.handleMessage(msg);         switch (msg.what) {            case 1:                 //需要做判空操作                if (activity != null) {                     activity.mTextView.setText("new Value");                 }                break;             default:                 Log.i(TAG, "handleMessage: default ");                break;         }      } }  @Override protected void onCreate(Bundle savedInstanceState) {     super.onCreate(savedInstanceState);    setContentView(R.layout.activity_main);     //在onCreate中初始化     activityWeakReference = new WeakReference<MainActivity>(this);     myHandler = new MyHandler(activityWeakReference);      myHandler.sendEmptyMessage(1);     mTextView = (TextView) findViewById(R.id.tv_test); } }復制代碼

        參考博文blog.csdn.net/ucxiii/arti…

        2.onNewIntent()的調用時機

        解析:

        在Android應用程序開發的時候,從一個Activity啟動另一個Activity并傳遞一些數據到新的Activity上非常簡單,但是當您需要讓后臺運行的Activity回到前臺并傳遞一些數據可能就會存在一點點小問題。

        首先,在默認情況下,當您通過Intent啟到一個Activity的時候,就算已經存在一個相同的正在運行的Activity,系統都會創建一個新的Activity實例并顯示出來。為了不讓Activity實例化多次,我們需要通過在AndroidManifest.xml配置activity的加載方式(launchMode)以實現單任務模式,如下所示:

        <activity  android:label="@string/app_name"android:launchmode="singleTask"android:name="Activity1"> </activity>復制代碼

        launchMode為singleTask的時候,通過Intent啟到一個Activity,如果系統已經存在一個實例,系統就會將請求發送到這個實例上,但這個時候,系統就不會再調用通常情況下我們處理請求數據的onCreate方法,而是調用onNewIntent方法

        答案:

        前提:ActivityA已經啟動過,處于當前應用的Activity堆棧中; 當ActivityA的LaunchMode為SingleTop時,如果ActivityA在棧頂,且現在要再啟動ActivityA,這時會調用onNewIntent()方法 當ActivityA的LaunchMode為SingleInstance,SingleTask時,如果已經ActivityA已經在堆棧中,那么此時會調用onNewIntent()方法

        當ActivityA的LaunchMode為Standard時,由于每次啟動ActivityA都是啟動新的實例,和原來啟動的沒關系,所以不會調用原來ActivityA的onNewIntent方法,仍然調用的是onCreate方法

        以下是代碼實例

        1.設置MainActivity的啟動模式為SingleTask(棧內復用)

        <activity android:name=".MainActivity"android:launchMode="singleTask"> <intent-filter> <action android:name="android.intent.action.MAIN" /> <category android:name="android.intent.category.LAUNCHER" />         </intent-filter>     </activity>復制代碼

        2.MainActivity中重寫onNewIntent方法

        package code.xzy.com.handlerdemo; import android.content.Intent; import android.os.Bundle; import android.support.v7.app.AppCompatActivity; import android.util.Log; import android.view.View; import android.widget.Button; import android.widget.Toast; public class MainActivity extends AppCompatActivity { private static final String TAG = "MainActivity"; private Button mButton;  @Override protected void onCreate(Bundle savedInstanceState) {     super.onCreate(savedInstanceState);    setContentView(R.layout.activity_main);     mButton = (Button) findViewById(R.id.forward_btn);     mButton.setOnClickListener(new View.OnClickListener() {         @Override         public void onClick(View view) {             startActivity(new Intent(MainActivity.this, Main2Activity.class));         }     });  }  @Override protected void onNewIntent(Intent intent) {     Toast.makeText(this, "onnewIntent", Toast.LENGTH_SHORT).show();     Log.i(TAG, "onNewIntent: i done...."); } }復制代碼

        3.Main2Actvity執行點擊跳轉,MainActivity被復用,執行onNewIntent方法

        package code.xzy.com.handlerdemo; import android.content.Intent; import android.os.Bundle; import android.support.v7.app.AppCompatActivity; import android.view.View; import android.widget.Button; public class Main2Activity extends AppCompatActivity { private Button mButton;  @Override protected void onCreate(Bundle savedInstanceState) {     super.onCreate(savedInstanceState);    setContentView(R.layout.activity_main2);      mButton = (Button)findViewById(R.id.btn);      mButton.setOnClickListener(new View.OnClickListener() {         @Override         public void onClick(View view) {             startActivity(new Intent(Main2Activity.this,MainActivity.class));             finish();         }     }); } }

        打印截圖

        **這里分享一份全套體系化高級架構視頻;**七大主流技術模塊,視頻+源碼+筆記(文末有詳細面試資料專題整理包分享

        3.RecyclerView相比ListView有哪些優勢

        解析:

        首先需要解釋下RecyclerView的這個名字了,從它類名上看,RecyclerView代表的意義是,我只管Recycler View,也就是說RecyclerView只管回收與復用View,其他的你可以自己去設置。可以看出其高度的解耦,給予你充分的定制自由(所以你才可以輕松的通過這個控件實現ListView,GirdView,瀑布流等效果)

        其次RecyclerView提供了添加、刪除item的動畫 效果,而且可以自定義

        RecyclerView相比ListView優勢在于可以輕松實現:

        1. ListView的功能
        2. GridView的功能
        3. 橫向ListView的功能
        4. 橫向ScrollView的功能
        5. 瀑布流效果
        6. 便于添加Item增加和移除動畫

        不過一個挺郁悶的地方就是,系統沒有提供ClickListener和LongClickListener。 不過我們也可以自己去添加,只是會多了些代碼而已。 實現的方式比較多,你可以通過mRecyclerView.addOnItemTouchListener去監聽然后去判斷手勢,

        當然你也可以通過adapter中自己去提供回調

        參考

        jcodecraeer.com/a/anzhuokai… blog.csdn.net/lmj62356579… www.360doc.com/content/16/…

        4.談一談Proguard混淆技術

        答案:

        Proguard技術有如下功能:

        壓縮 –檢查并移除代碼中無用的類 優化–對字節碼的優化,移除無用的字節碼 混淆–混淆定義的名稱,避免反編譯

        預監測–在java平臺對處理后的代碼再次進行檢測

        代碼混淆只在上線時才會用到,debug模式下會關閉,是一種可選的技術。

        那么為什么要使用代碼混淆呢?

        因為Java是一種跨平臺的解釋性開發語言,而java的源代碼會被編譯成字節碼文件,存儲在.class文件中,由于跨平臺的需要,java的字節碼中包含了很多源代碼信息,諸如變量名、方法名等等。并且通過這些名稱來訪問變量和方法,這些變量很多是無意義的,但是又很容易反編譯成java源代碼,為了防止這種現象,我們就需要通過proguard來對java的字節碼進行混淆,混淆就是對發布的程序進行重新組織和處理,使得處理后的代碼與處理前的代碼有相同的功能,和不同的代碼展示,即使被反編譯也很難讀懂代碼的含義,哪些混淆過的代碼仍能按照之前的邏輯執行得到一樣的結果。

        但是,某些java類是不能被混淆的,比如實現了序列化的java類是不能被混淆的,否則反序列化時會出問題。

        下面這類代碼混淆的時候要注意保留,不能混淆。

        • Android系統組件,系統組件有固定的方法被系統調用。
        • 被Android Resource 文件引用到的。名字已經固定,也不能混淆,比如自定義的View 。
        • Android Parcelable ,需要使用android 序列化的。

        其他Anroid 官方建議 不混淆的,如

        • android.app.backup.BackupAgentHelper?
        • android.preference.Preference?
        • com.android.vending.licensing.ILicensingService?
        • Java序列化方法,系統序列化需要固定的方法。?
        • 枚舉 ,系統需要處理枚舉的固定方法。?
        • 本地方法,不能修改本地方法名?
        • annotations 注釋?
        • 數據庫驅動?
        • 有些resource 文件用到反射的地方

        5.ANR出現的場景及解決方案

        在Android中,應用的響應性被活動管理器(Activity Manager)和窗口管理器(Window Manager)這兩個系統服務所監視。當用戶觸發了輸入事件(如鍵盤輸入,點擊按鈕等),如果應用5秒內沒有響應用戶的輸入事件,那么,Android會認為該應用無響應,便彈出ANR對話框。而彈出ANR異常,也主要是為了提升用戶體驗。

        解決方案是對于耗時的操作,比如訪問網絡、訪問數據庫等操作,需要開辟子線程,在子線程處理耗時的操作,主線程主要實現UI的操作

        6.HTTPS中SSL證書認證的過程

        7.簡述Android的Activity的內部機制

        8.對Android Framework層的某一個模塊(或者System App)做簡要介紹

        9.Android Handler的機制和原理

        主線程使用Handler的過程

        首先在主線程創建一個Handler對象 ,并重寫handleMessage()方法。然后當在子線程中需要進行更新UI的操作,我們就創建一個Message對象,并通過handler發送這條消息出去。之后這條消息被加入到MessageQueue隊列中等待被處理,通過Looper對象會一直嘗試從Message Queue中取出待處理的消息,最后分發會Handler的handler Message()方法中。

        參考 blog.csdn.net/u012827296/…

        10.線程間通信和進程間通信有什么不同,Android開發過程中是怎么實現的

        www.cnblogs.com/yangtao1995…

        11.簡述項目中對于內存優化的幾個細節點

        答案:

        1. 當查詢完數據庫之后,及時關閉Cursor對象。
        2. 記得在Activity的onPause方法中調用unregisterReceiver()方法,反注冊廣播
        3. 避免Content內存泄漏,比如在4.0.1之前的版本上不要講Drawer對象置為static。當一個Drawable綁定到了View上,實際上這個View對象就會成為這個Drawable的一個callback成員變量,上面的例子中靜態的sBackground持有TextView對象lable的引用,而lable只有Activity的引用,而Activity會持有其他
        贊(0)
        分享到: 更多 (0)
        網站地圖   滬ICP備18035694號-2    滬公網安備31011702889846號
        主站蜘蛛池模板: 亚洲精品综合一二三区在线| 国产精品xxxx国产喷水亚洲国产精品无码久久一区 | 国产欧美日韩综合精品二区| 国产99视频精品免视看7 | 久久久久久噜噜精品免费直播| 久久精品国产免费一区| 精品乱码一区二区三区四区| 97人妻无码一区二区精品免费| 精品无码国产污污污免费网站国产| 国产精品久久网| 久久99国产综合精品免费| 亚洲精品国自产拍在线观看| 国产伦精品一区二区三区视频猫咪| 欧美精品亚洲精品日韩| 国产l精品国产亚洲区在线观看| 亚洲AV永久无码精品成人| 人妻少妇精品系列| 精品国偷自产在线视频| 国产精品粉嫩美女在线观看| 一区二区三区四区精品视频| 久久成人国产精品二三区| 97人妻无码一区二区精品免费| 精品久久久噜噜噜久久久 | 国内精品视频在线观看| 成人国产精品日本在线观看| 国产精品亚洲A∨天堂不卡| 久久精品麻豆日日躁夜夜躁| 亚洲AV永久无码精品网站在线观看| 午夜肉伦伦影院久久精品免费看国产一区二区三区 | 人人妻人人澡人人爽人人精品| 亚洲午夜国产精品无码| 久久国产综合精品五月天| 性色精品视频网站在线观看| 日韩精品无码一区二区三区不卡| 麻豆国内精品久久久久久| 精品视频在线观看你懂的一区| 久久99国产精品久久| 国产精品成人观看视频国产| 九九热这里只有在线精品视| 亚洲国产成人久久精品动漫| 777久久精品一区二区三区无码|