2015年Android開發(fā)新技術(shù)小結(jié)
開發(fā)工具
Android Studio: Google 官方放棄 Eclipse 和 Android Studio 普及。AS 雖然不算新,但是對 Android Studio 這個(gè)軟件的更新速度快的驚人,有大量的新功能發(fā)布。例如支持很多注解代碼提示注解、Live code template、支持自動生成 Parcelable 實(shí)現(xiàn)等等,作為開發(fā)者,持續(xù)關(guān)注這個(gè)更新列表 Recent Changes,一定會讓你的寫代碼的生活更加美好。
編程語言
otlin: 作為 Android 領(lǐng)域的 Swift,絕對讓你如沐新風(fēng)。拋棄沉重的 Java 語法,Kotlin 融入了很多現(xiàn)代編程語言的思想,作為開發(fā)者,接受新的語言,了解新語言的發(fā)展趨勢,更有利于開闊你的思路和加深對語言的理解。在 Android 開發(fā)上,使用 Kotlin 并不會讓你付出什么代價(jià),為什么不來試試? 使用Kotlin進(jìn)行Android開發(fā)。
React Native: 跨平臺一直是程序員的夢想,而且移動應(yīng)用的跨平臺解決方案也很多,因?yàn)?Facebook 的參與和力推,讓這個(gè)解決方案帶上了光環(huán)。第一個(gè)用 React Native 開發(fā)的 App 已經(jīng)在 Google Play 上架 Facebook 廣告管理工具,聽說 Android 的 SDK 也馬上會到來,React Native。
Sky: 與 React Native 類似,使用 Web 開發(fā)語言來做移動平臺的開發(fā),雖然這個(gè)只是一個(gè)嘗試,但是這是 Google 自身推出的,特別是在 Java 語言的使用上敗訴之后,這可能會有一些作為呢,domokit/sky_sdk。
開發(fā)模式
Dagger 2:依賴注入并不是什么新技術(shù),但是使用在 Android 確實(shí)一個(gè)新的嘗試。Android App 越來越被當(dāng)成嚴(yán)肅的大型項(xiàng)目來構(gòu)建,很多在以前大型服務(wù)器開發(fā)上使用的技術(shù)都被應(yīng)用到了移動開發(fā)。Android 開發(fā)分模塊開發(fā),使用 Dagger 來松耦合模塊。特別值得一體的是,Dagger 2 現(xiàn)在由 Google 親自接管。
MVP:因?yàn)?Android 并沒有嚴(yán)格的業(yè)務(wù)和界面區(qū)分,項(xiàng)目一復(fù)雜,就很容易使代碼陷入混亂。現(xiàn)在 Android 開發(fā)社區(qū)對 MVP 模式討論越來越熱,覺得 MVP 是非常適合 Android APP 開發(fā)。
RxAndroid: 函數(shù)響應(yīng)式編程(Functional Reactive Programming)也不是新內(nèi)容,RxAndroid 把 RxJava 帶到 Android 環(huán)境中。很多時(shí)候,編寫 Android 程序,你也可以看成是數(shù)據(jù)的處理和流動,換一種思想編程,曾經(jīng)看起來很棘手的問題,瞬間就很優(yōu)雅的解決了。
MVVM: 這是因?yàn)殚_始官方支持 DataBinding,把 MVVM 直接帶到 Android 中。數(shù)據(jù)綁定在 Windows WPF 和 Web 已經(jīng)非常常見,它非常高效的開發(fā)效率,讓你只關(guān)心你的數(shù)據(jù)和業(yè)務(wù)。這也對 Android 開發(fā)來說,無疑是一個(gè)非常重大的影響。
插件化:針對大型 Android 項(xiàng)目,很多 App 開始使用插件來分模塊構(gòu)建相對獨(dú)立的功能。
Hybrid:完全使用 HTML 5 開發(fā) App,目前還不成熟。但是折中方案在很多情況下是非常適合的,典型的就是微信,大部分信息展示都是通過 H5 來完成,同時(shí)通過 Hybird 方式,把 Web 和 Native 打通,提供給網(wǎng)頁訪問本地資源的能力。
UI設(shè)計(jì)
Material Design:已經(jīng)紅遍了大江南北,這方面的討論實(shí)在太多了,而且各種支持庫都有了,特別是 Google 官方出了一個(gè)支持庫 Android Design Support Library。
Sketch 3: 這是一個(gè)專為設(shè)計(jì)移動端 UI 的設(shè)計(jì)工具,作為開發(fā)者,不用懂那么復(fù)雜的 PS 使用,也可以做非常專業(yè)設(shè)計(jì):https://designcode.io/sketch
說了這么,感覺還有很多東西沒有說到,技術(shù)的發(fā)展是很快,我們可能跟不上每個(gè)細(xì)節(jié),但是我們會發(fā)現(xiàn)這些新技術(shù),很多地方都是相通的。對于開發(fā)者,能夠保持對新技術(shù)的好奇和興趣時(shí)非常難得的,參與到新技術(shù)中是技術(shù)修養(yǎng),引領(lǐng)新技術(shù)的發(fā)展,那就是大神了。
相關(guān)文章:
1. ASP.NET MVC把數(shù)據(jù)庫中枚舉項(xiàng)的數(shù)字轉(zhuǎn)換成文字2. 用xslt+css讓RSS顯示的跟網(wǎng)頁一樣漂亮3. 《CSS3實(shí)戰(zhàn)》筆記--漸變設(shè)計(jì)(一)4. .NET擴(kuò)展方法使用實(shí)例詳解5. 測試模式 - XSL教程 - 56. 讓chatgpt將html中的圖片轉(zhuǎn)為base64方法示例7. html5手機(jī)觸屏touch事件介紹8. CSS3實(shí)現(xiàn)動態(tài)翻牌效果 仿百度貼吧3D翻牌一次動畫特效9. ASP.NET Core自定義中間件的方式詳解10. ASP.NET泛型三之使用協(xié)變和逆變實(shí)現(xiàn)類型轉(zhuǎn)換
