Kotlin使用静态变量与静态方法详解
作者:水月沐風
kotlin定义静态变量、方法可以采用伴生对象companion object的方式。 下面这篇文章主要给大家介绍了关于Kotlin使用静态变量与静态方法的相关资料,需要的朋友可以参考下
前言
在日常开发过程中,静态变量和 静态方法 是我们常见的用法,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方面的文章,大家拭目以待。
总结
以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,如果有疑问大家可以留言交流,谢谢大家对脚本之家的支持。