Android教程網
  1. 首頁
  2. Android 技術
  3. Android 手機
  4. Android 系統教程
  5. Android 游戲
 Android教程網 >> Android技術 >> Android開發 >> 初級開發 >> 關於Android誤解一二

關於Android誤解一二

編輯:初級開發

1、前言
  2009, 6月26日,Google Android發布了NDK,引起了很多發人員的興趣。NDK全稱:Native Development Kit。下載地址為:http://developer.android.com/sdk/ndk/1.5_r1/index.Html。2、誤解
  新出生的事物,除了驚喜外,也會給我們帶來一定的迷惑、誤解。
2.1、誤解一: NDK 發布之前, android 不支持進行 C 開發 
 在Google 中搜索 “NDK” ,很多 “Android 終於可以使用 C++ 開發 ” 之類的標題,這是一種對 Android 平台編程方式的誤解。其實, Android 平台從誕生起,就已經支持 C 、 C++ 開發。眾所周知, Android 的 SDK 基於 Java 實現,這意味著基於 Android SDK 進行開發的第三方應用都必須使用 Java 語言。但這並不等同於 “ 第三方應用只能使用 Java” 。在 Android SDK 首次發布時, Google 就宣稱其虛擬機 Dalvik 支持 JNI 編程方式,也就是第三方應用完全可以通過 JNI 調用自己的 C 動態庫,即在 android 平台上, “Java+C” 的編程方式是一直都可以實現的。

 當然這種誤解的產生是有根源的:在android SDK 文檔裡,找不到任何 JNI 方面的幫助。即使第三方應用開發者使用 JNI 完成了自己的 C 動態鏈接庫( so )開發,但是 so 如何和應用程序一起打包成 apk 並發布?這裡面也存在技術障礙。我曾經花了不少時間,安裝交叉編譯器創建 so ,並通過 asset (資源)方式,實現捆綁 so 發布。但這種方式只能屬於取巧的方式,並非官方支持。所以,在 NDK 出來之前,我們將 “Java+C” 的開發模式稱之為灰色模式,即官方既不聲明 “ 支持這種方式 ” ,也不聲明 “ 不支持這種方式 ” 。

2.2、誤解二:有了 NDK ,我們可以使用純 C 開發 android 應用 
 android SDK采用 Java 語言發布,把眾多的 C 開發人員排除在第三方應用開發外( 注意:我們所有討論都是基於“ 第三方應用開發 ” , Android 系統基於 Linux ,系統級別的開發肯定是支持 C 語言的。 )。NDK 的發布,許多人會誤以為,類似於 SymBian 、 WM ,在 android 平台上終於可以使用純 C 、 C++ 開發第三方應用了!其實不然, NDK 文檔明確說明: it is not a good way 。因為 NDK 並沒有提供各種系統事件處理支持,也沒有提供應用程序生命周期維護。此外,在本次發布的 NDK 中,應用程序 UI 方面的 API 也沒有提供。至少目前來說,使用純 C 、 C++ 開發一個完整應用的條件還不完備。

3、NDK是什麼
對NDK進行了粗略的研究後,我對“NDK是什麼”的理解如下:
1、NDK是一系列工具的集合。
NDK提供了一系列的工具,幫助開發者快速開發C(或C++)的動態庫,並能自動將so和java應用一起打包成apk。這些工具對開發者的幫助是巨大的。  NDK集成了交叉編譯器,並提供了相應的mk文件隔離CPU、平台、ABI等差異,開發人員只需要簡單修改mk文件(指出“哪些文件需要編譯”、“編譯特性要求”等),就可以創建出so。  NDK可以自動地將so和Java應用一起打包,極大地減輕了開發人員的打包工作。  2、NDK提供了一份穩定、功能有限的API頭文件聲明。  Google明確聲明該API是穩定的,在後續所有版本中都穩定支持當前發布的API。從該版本的NDK中看出,這些API支持的功能非常有限,包含有:C標准庫(libc)、標准數學庫(libm)、壓縮庫(libz)、Log庫(liblog)。 4、NDK帶來什麼1、NDK的發布,使“Java+C”的開發方式終於轉正,成為官方支持的開發方式。使用NDK,我們可以將要求高性能的應用邏輯使用C開發,從而提高應用程序的執行效率。  使用NDK,我們可以將需要保密的應用邏輯使用C開發。畢竟,Java包都是可以反編譯的。  NDK促使專業so組件商的出現。(樂觀猜想,要視乎Android用戶的數量)  2、NDK將是Android平台支持C開發的開端。  NDK提供了的開發工具集合,使開發人員可以便捷地開發、發布C組件。同時,Google承諾在NDK後續版本中提高“可調式”能力,即提供遠程的gdb工具,使我們可以便捷地調試C源碼。在支持Android平台C開發,我們能感覺到Google花費了很大精力,我們有理由憧憬“C組件支持”只是Google Android平台上C開發的開端。畢竟,C程序員仍然是碼農陣營中的絕對主力,將這部分人排除在Android應用開發之外,顯然是不利於android平台繁榮昌盛的。

 官方說法:

 android是一個開放的系統,這個系統體積非常龐大,不同的開發者在開發過程中並不需要掌握整個android
  系統,只要進行其中某一個部分的開發
  android 的開發分四個層次
  1. Linux操作系統及驅動,該層由C語言實現
  2. 本地代碼框架,該層次由C,C++實現
  3. java框架,該層主要由Java實現
  4. java應用程序,該層主要由Java實現

android目前不能純粹使用c/c++開發,必須使用Java調用由c++開發的.so庫。

google沒有提供給c++ UI接口。android應用程序框架是Java的。

也就是說android程序只能運行在dalvik虛擬機上。

網友的觀點:

按照Android的架構, 跟用戶打交道的代碼只可以是java代碼。 然後java中有一項叫做JNI的技術,可以調用底層的動態鏈接庫so,這些so都是C/C++的代碼, SO提供的接口就是android自身攜帶的NDK工具。但似乎這樣做沒有必要,原因是,采用JNI技術調用C,用到的場景是處理任務繁重的計算,Java的效率達不到,但作為終端產品,手機相當於ClIEnt,很少情況會處理復雜的運算,終端產品最終走的是雲計算模式(把計算量大的工作交給雲端實現)。這大致是android的設計思路。 如果你有興趣,可以了解一下google語音搜索app, 裡面有語音處理程序,語音識別是在手機端實現的,並且計算量龐大,裡面應該包含NDK的調用。

  1. 上一頁:
  2. 下一頁:
熱門文章
閱讀排行版
Copyright © Android教程網 All Rights Reserved