1、前言
2009年6月26日,Google Android發(fā)布了NDK,引起了很多發(fā)人員的興趣。NDK全稱:Native Development Kit。下載地址為:http://developer.android.com/sdk/ndk/1.5_r1/index.html。
2、誤解
新出生的事物,除了驚喜外,也會給我們帶來一定的迷惑、誤解。
在Google中搜索“NDK”,很多“Android終于可以使用C++開發(fā)”之類的標題,這是一種對Android平臺編程方式的誤解。其實,Android平臺從誕生起,就已經(jīng)支持C、C++開發(fā)。眾所周知,Android的SDK基于Java實現(xiàn),這意味著基于Android SDK進行開發(fā)的第三方應用都必須使用Java語言。但這并不等同于“第三方應用只能使用Java”。在Android SDK首次發(fā)布時,Google就宣稱其虛擬機Dalvik支持JNI編程方式,也就是第三方應用完全可以通過JNI調(diào)用自己的C動態(tài)庫,即在Android平臺上,“Java+C”的編程方式是一直都可以實現(xiàn)的。
當然這種誤解的產(chǎn)生是有根源的:在Android SDK文檔里,找不到任何JNI方面的幫助。即使第三方應用開發(fā)者使用JNI完成了自己的C動態(tài)鏈接庫(so)開發(fā),但是so如何和應用程序一起打包成apk并發(fā)布?這里面也存在技術障礙。我曾經(jīng)花了不少時間,安裝交叉編譯器創(chuàng)建so,并通過asset(資源)方式,實現(xiàn)捆綁so發(fā)布。但這種方式只能屬于取巧的方式,并非官方支持。所以,在NDK出來之前,我們將“Java+C”的開發(fā)模式稱之為灰色模式,即官方既不聲明“支持這種方式”,也不聲明“不支持這種方式”。
2.2、誤解二:有了NDK,我們可以使用純C開發(fā)Android應用
Android SDK采用Java語言發(fā)布,把眾多的C開發(fā)人員排除在第三方應用開發(fā)外(注意:我們所有討論都是基于“第三方應用開發(fā)”,Android系統(tǒng)基于Linux,系統(tǒng)級別的開發(fā)肯定是支持C語言的。)。NDK的發(fā)布,許多人會誤以為,類似于Symbian、WM,在Android平臺上終于可以使用純C、C++開發(fā)第三方應用了!其實不然,NDK文檔明確說明:it is not a good way。因為NDK并沒有提供各種系統(tǒng)事件處理支持,也沒有提供應用程序生命周期維護。此外,在本次發(fā)布的NDK中,應用程序UI方面的API也沒有提供。至少目前來說,使用純C、C++開發(fā)一個完整應用的條件還不完備。
3、NDK是什么
對NDK進行了粗略的研究后,我對“NDK是什么”的理解如下:
1、NDK是一系列工具的集合。
2、NDK提供了一份穩(wěn)定、功能有限的API頭文件聲明。
Google明確聲明該API是穩(wěn)定的,在后續(xù)所有版本中都穩(wěn)定支持當前發(fā)布的API。從該版本的NDK中看出,這些API支持的功能非常有限,包含有:C標準庫(libc)、標準數(shù)學庫(libm)、壓縮庫(libz)、Log庫(liblog)。
4、NDK帶來什么
1) NDK的發(fā)布,使“Java+C”的開發(fā)方式終于轉(zhuǎn)正,成為官方支持的開發(fā)方式。
2)NDK將是Android平臺支持C開發(fā)的開端。
NDK提供了的開發(fā)工具集合,使開發(fā)人員可以便捷地開發(fā)、發(fā)布C組件。同時,Google承諾在NDK后續(xù)版本中提高“可調(diào)式”能力,即提供遠程的gdb工具,使我們可以便捷地調(diào)試C源碼。在支持Android平臺C開發(fā),我們能感覺到Google花費了很大精力,我們有理由憧憬“C組件支持”只是Google Android平臺上C開發(fā)的開端。畢竟,C程序員仍然是碼農(nóng)陣營中的絕對主力,將這部分人排除在Android應用開發(fā)之外,顯然是不利于Android平臺繁榮昌盛的。