隨着Android SDK版本不斷的迭代更新,在新的SDK上總是會出現讓人眼前一亮非常方便好用的API。但是這些新的API呢在低版本的SDK上是沒有的,所以當我們的minSdkVersion的版本低於新API所在的版本時,我們直接使用新API在編譯時會出現報錯。如果只是想解決編譯報錯的問題呢,Android給我們提供了兩種註解的方式避免編譯時報錯:
@SuppressLint
@TargetApi
這兩種方法又有什麼區別呢?
. SupressLint和TargetApi
SupressLint很顯然的意思是忽略Lint檢查,對於我們使用高版本API來說,可以使用@SuppressLint("NewApi")的方式讓Lint在編譯時忽略所調用API對版本的要求。而@TargetApi是忽略特定版本的API調用報錯。
舉個栗子:當你的項目minSdkVersion=9,你想使用API 11的新的方法時。此時,使用@TargetApi(11)和@SuppressLint("NewApi")的效果一樣,代碼都不會報錯。但是如果你使用了Api 19纔出現的新的方法時,在使用@TargetApi的方法中還是會給你報錯,而在另一個方式中依然不會報錯。
那這麼講使用@SuppressLint("NewApi")就更好了?
. 正確的使用姿勢
當然不是啦!我們要清楚一點,使用上面兩種註釋的方式只是讓lint在編譯時不再報錯,在低版本的手機系統中,如果直接使用高版本的API肯定會報:“NoSuchMethod”的Crash的。
所以正確的做法應該是在註解的方法中,做版本判斷,在低版本中依然使用老的方式處理。版本判斷時我們需要判斷具體的版本號,比如
1@TargetApi(9)
2public void doSomeThing() {
3 if(Build.VERSION.SDK_INT >= 9) {
4 // 此時我們正常使用API 9的方法,如果這裏誤使用了Api 11中的方法,編譯時就會報錯
5 // 提醒我們只是引入API 9中的方法
6 } else {
7 // TODO 使用老的方式
8 }
9}
10
11@SuppressLint("NewApi")
12public void doOthers() {
13 if(Build.VERSION.SDK_INT >= 9) {
14 // 此時我們正常使用API 9的方法,如果這裏誤使用了Api 11中的方法,編譯不會報錯
15 // 那麼運行在低版本中將會引發Crash的風險
16 } else {
17 // TODO 使用老的方式
18 }
19}
所以,我們推薦使用@TargetApi的方式比較安全。
本公衆號送書活動持續火熱進行中哦!《Effective Java》、《編程之美》、《利用Python進行數據分析》、《Android羣英傳》等暢銷書籍免費送哦。
????送書啦!送書啦!????
如果覺得本文對你有一點點的幫助,可以關注本公衆號????????閱讀更多哦~