1. 程式人生 > >2014金山網路實習生招聘——Android筆試題

2014金山網路實習生招聘——Android筆試題

一、請用虛擬碼描述,在Android系統上啟動和停止Service有哪些方法,並說明這些方法導致Service的生命週期有何不同?

二、輸入一個正整數 X,以2*X,4*X,8*X的方式遞增,當大於10000時,再倒敘輸出已經輸出的整數。【要求:不得使用迴圈和其他任何變數(包含區域性變數)輔助】

比如 X= 2468,輸出結果為:

2468,4936,9872,19744,19744,9872,4936,2468

三、有兩個字串由不同的字母組成,一長一短,長的為A,短的為B。設計一個演算法,如果所有在B中出現的字元都在A中出現,則返回true,否則返回false。假設A的長度為m,B的長度為n,要求演算法時間複雜度不能大於O(m+n)。

四、實現如下工作者類IKWorker,呼叫者通過呼叫AddJob將Runnable型別的job提交給IKWorker,IKWorker負責非同步執行所有提交過來的job。【要求:儘量高效,不得使用系統的執行緒池】

 public interface IKWorker{

public boolean Start();

public void AddJob(Runnable job);

public boolean Stop();

}

五、在Android手機中實現一個App,用來做檔案下載,可在App介面新增,暫停和取消下載檔案及展示下載過程中的進度,同時要保證Activity退出時後臺仍然能再下載。當介面啟動時還可以顯示正在下載的檔案及進度。【要求:寫出實現此App的設計思想,儘量易懂,簡潔】

六、系統/sdcard/目錄下有很多張圖片,現需要一activity通過縮圖的方式瀏覽所有圖片,在設計中體現對一下三點的處理:

A.不能分頁顯示,所有圖片顯示在一頁

B.要體現對ANR的處理

C.要體現對OOM的處理

請寫出此Activity的設計思路

七、在Android中兩個程序之間傳輸大資料,可以使用什麼方式實現?這些方式中哪種方式最高效?說明原因。