前言
在日常開發過程中,靜態變量和 靜態方法 是我們常見的用法,Java中相信大家并不陌生了,那么在 Kotlin 中該如何使用呢?
其實很簡單,只需要一個將變量和方法包含在 companion object 域中即可,比如這樣:
class Constant { companion object { // 接口根地址 const val BASE_URL = "http://xxxx.xxx.xxx/" // 友盟 const val UMENG_APP_KEY = "xxxxxxxxxx" const val UMENG_CHANNEL = "umeng" // 微博 const val WEIBO_APP_KEY = "xxxxxxxx" const val WEIBO_SECRET = "xxxxxxxxxx" fun getVideoFactor(){ // do some work } }}
看后是不是很簡單?在純kotlin代碼中可以直接這樣使用:
//初始化各平臺的APIKey PlatformConfig.setWeixin(Constant.WECHAT_APP_ID, Constant.WECHAT_APP_SECRET) PlatformConfig.setSinaWeibo(Constant.WEIBO_APP_KEY, Constant.WEIBO_SECRET, Constant.WEIBO_AUTH_RETURN_URL)
然而,如果我們使用的是Java和kotlin混合開發,在Java代碼中就無法通過 Constant.靜態變量 的方式來使用靜態變量或者方法來,而是通過如下方式:
//初始化各平臺的APIKey PlatformConfig.setWeixin(Constant.Companion.WECHAT_APP_ID, Constant.WECHAT_APP_SECRET) PlatformConfig.setSinaWeibo(Constant.Companion.WEIBO_APP_KEY, Constant.WEIBO_SECRET, Constant.WEIBO_AUTH_RETURN_URL)
如果我們想像kotlin那樣直接通過 類名.靜態變量 方式使用呢?我們可以借助于注解 @JvmField 和 @JvmStatic 來分別標注靜態變量和靜態方法,之后我就能在Java代碼中像以前方式那樣直接使用靜態的成員啦!
例如這樣:
/** * @author moosphon on 2018/12/12 * desc: 異常的統一處理者 */class ExceptionHandler { companion object { @JvmField var errorCode = NetRequestStatus.UNKNOWN_ERROR @JvmField var errorMessage = "請求失敗,請稍后重試" @JvmStatic fun handleException(e : Throwable): String{ e.printStackTrace() when(e){ is SocketException -> { Logger.e("ExceptionHandler", "網絡連接異常: " + e.message) errorCode = NetRequestStatus.NETWORK_ERROR errorMessage = "網絡連接異常" } is JsonParseException -> { Logger.e("ExceptionHandler", "數據解析異常: " + e.message) errorCode = NetRequestStatus.PARSE_ERROR errorMessage = "數據解析異常" } else -> { try { Logger.e("ExceptionHandler", "其他錯誤: " + e.message) } catch (e1: Exception) { Logger.e("ExceptionHandler", "未知錯誤: " + e.message) } errorCode = NetRequestStatus.UNKNOWN_ERROR errorMessage = "未知錯誤,一起禱告快點好起來吧~" } } return errorMessage } }}
前段時間比較忙,之后會繼續為大家帶來kotlin方面的文章,大家拭目以待。
總結
以上就是這篇文章的全部內容了,希望本文的內容對大家的學習或者工作具有一定的參考學習價值,如果有疑問大家可以留言交流,謝謝大家對VeVb武林網的支持。
新聞熱點
疑難解答