欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Android中封裝SDK時常用的注解總結(jié)

 更新時間:2017年05月04日 09:42:26   作者:Xie Zefan  
這篇文章主要給大家總結(jié)了在Android中封裝SDK時常用的注解的相關(guān)資料,文中介紹的非常詳細(xì),對大家具有一定的參考學(xué)習(xí)價值,需要的朋友們下面來一起看看吧。

前言

在工作中我們經(jīng)常需要將功能模塊封裝成庫供合作廠商調(diào)用, 如何寫好一個健壯的Android Library有很多講究,使用注解可以對SDK暴露給開發(fā)者的接口做出一些限制,從而盡可能地避免開發(fā)者錯誤地使用API。 下面我們介紹幾種封裝SDK時常用到的注解,需要的朋友們可以參考學(xué)習(xí)。

一、IntDef與StringDef

我們有時候會使用int常量或者String常量來代替枚舉, 特別在你編寫SDK的時候,你可以通過IntDef或者StringDef來限制接口可接受的參數(shù)。

比如,有一個 disableChannel的接口,用來關(guān)閉指定的channel 。 我們可以先定義自己的注解@RequirePayChannel

public static final int CHANNEL_UNIONPAY = 0x11000;
public static final int CHANNEL_ALIPAY = 0x12000;
public static final int CHANNEL_WECHAT = 0x13000;
@Retention(RetentionPolicy.SOURCE)
@IntDef({CHANNEL_UNIONPAY,CHANNEL_ALIPAY,CHANNEL_WECHAT})
public @interface RequirePayChannel {}

這樣,你便可以通過@RequirePayChannel來指定disableChannel()的可接受參數(shù)

public void enableChannel(@RequirePayChannel int channel) {
 // do something
}

這樣,一些IDE還會自動提供給你建議參數(shù)。如果填入指點(diǎn)范圍之外的參數(shù),將會出現(xiàn)錯誤提示并無法編譯通過。


值得一說的是, 在這里,我們使用到了@Retention(RetentionPolicy.SOURCE) 。 它指定了編譯器在處理Animation時候的處理方法。 默認(rèn)編譯器會將常量替換成對應(yīng)的數(shù)值,如果沒指定該注解,你編譯完成后將得到這樣的class文件:


這樣會導(dǎo)致IDE不能提示到有意義的信息。并且一定要指定為特定的int數(shù)值,否則也無法編譯通過。


所以,應(yīng)該指定Retention讓編譯器不對該注解做額外的優(yōu)化處理。

二、DrawableRes, StringRes 與 DimenRes

當(dāng)我們在編寫指定資源文件的接口時,可以通過資源注解來指定該方法接受的資源類型。 指定錯誤的資源將不能編譯通過。 下面代碼中,我們使用@DrawableRes來表明setLogo方法只支持Drawable資源的ID。

public void setLogo(@DrawableRes int resurceId) {
 // do something
}

當(dāng)我們提供錯誤的資源,IDE將會報錯。


@StringRes @DimenRes 的使用方法也類似。

三、NonNull 與 Nullable

將一個空值傳入一個方法中可能引發(fā)潛在的Crash。 我們應(yīng)該極力避免這種情況, @NonNull 可以指定參數(shù)是否接受空值,當(dāng)我們傳入一個空值的時候,IDE會給出響應(yīng)的警告。 我們可以這樣使用它:

public void setContext(@NonNull Context context) {
 // do something
}

當(dāng)我們對其傳入一個空值的時候,將會顯示警告(但代碼仍然能通過編譯)

@Nullable 用于修飾參數(shù)或者方法的返回值可能為空,提醒開發(fā)者主要空值檢查。

@Nullable
public Context getContext() {return null;}

總結(jié)

以上就是這篇文章的全部內(nèi)容了,希望本文的內(nèi)容對大家的學(xué)習(xí)或者工作能帶來一定的幫助,如果有疑問大家可以留言交流,謝謝大家對腳本之家的支持。

相關(guān)文章

最新評論