Kandroid代碼篇 (1) 簡單Logger封裝

  • 簡單 Logger 封裝需求
  • kotlin 封裝實(shí)現(xiàn)
  • kotlin 相關(guān)知識(shí)點(diǎn)

一浊伙、簡單 Logger 封裝需求

??本需求是一個(gè)簡單的 Logger 需求爽醋,旨在簡單的控制 Logger 日志的耻蛇,輸出時(shí)間纤子、及輸出 tag 動(dòng)態(tài)更新。需求如下:

  • 代碼控制 Logger 日志輸出睡蟋,默認(rèn)不輸出日志踏幻;

  • 日志輸出時(shí)可以指定日志的 tag 標(biāo)簽,當(dāng)不指定時(shí)默認(rèn)為項(xiàng)目名稱戳杀;

  • 符合 Android 系統(tǒng) Log 調(diào)用習(xí)慣该面。

二、kotlin 封裝實(shí)現(xiàn)

  • 需求實(shí)現(xiàn)信卡,使用 Kotlin 實(shí)現(xiàn)對(duì) Logger 日志功能隔缀,并支持 Java 的對(duì)應(yīng)調(diào)用。
class OkLogger {

    companion object {  // 1??
        private const val DEF_TAG = "okLogger"

        // 伴生屬性傍菇,相當(dāng)于Java的靜態(tài)類成員變量
        var debug: Boolean = false  // 2??
            private set

        var tag: String = this.DEF_TAG
            private set

        private fun isPrint(message: String) = debug && !TextUtils.isEmpty(message)

        @JvmOverloads   // 3??
        @JvmStatic      // 4??
        fun setLogger(enable: Boolean = true, tag: String = DEF_TAG) {   // 5??
            this.tag = tag
            this.debug = enable
        }

        @JvmOverloads
        @JvmStatic
        fun v(message: String, tag: String = this.tag) {
            if (isPrint(message)) Log.v(tag, message)
        }

        @JvmOverloads
        @JvmStatic
        fun d(message: String, tag: String = this.tag) {
            if (isPrint(message)) Log.d(tag, message)
        }

        @JvmOverloads
        @JvmStatic
        fun i(message: String, tag: String = this.tag) {
            if (isPrint(message)) Log.i(tag, message)
        }

        @JvmOverloads
        @JvmStatic
        fun w(message: String, tag: String = this.tag) {
            if (isPrint(message)) Log.w(tag, message)
        }

        @JvmOverloads
        @JvmStatic
        fun e(message: String, tag: String = this.tag) {
            if (isPrint(message)) Log.e(tag, message)
        }

        @JvmStatic
        fun printStackTrace(throwable: Throwable?) {
            if (debug) {
                throwable?.printStackTrace()    // 6??
            }
        }
    }
}
  • Kotlin 語言掉用 OkLogger 開啟并輸出日志猾瘸。
OkLogger.setLogger(tag = "RabbitPrj")
OkLogger.d("message: onCreate is done.")
OkLogger.v("message warning: onCreate is done.", "warning")

// 輸出日志
cn.rabbit.example D/RabbitPrj: message: onCreate is done.
cn.rabbit.example V/warning: message warning: onCreate is done.
  • Java 語言調(diào)用 OkLogger 開啟并輸出日志。
OkLogger.setLogger(true, "RabbitPrj");
OkLogger.d("message: onCreate is done.");
OkLogger.v("message warning: onCreate is done.", "warning");

// 輸出日志
cn.rabbit.example D/RabbitPrj: message: onCreate is done.
cn.rabbit.example V/warning: message warning: onCreate is done.

三丢习、kotlin 相關(guān)知識(shí)點(diǎn)

  • 上述代碼第1??行使用 OkLogger 的伴生對(duì)象實(shí)現(xiàn)日志的輸出功能牵触,是考慮在 Java 中也可以簡單的調(diào)用,像使用系統(tǒng)的 Log 一樣簡單泛领;Kotlin 的伴生對(duì)象中定義的屬性荒吏、及函數(shù),相當(dāng)于 Java 中類的 靜態(tài)成員變量靜態(tài)方法渊鞋。“伴生對(duì)象知識(shí)傳輸門”

  • 代碼第2??行绰更,在 OkLogger 的伴生對(duì)象中定義了一個(gè)屬性 debug瞧挤,用于控制日志的輸出,同時(shí)設(shè)置屬性 debugsetter 訪問器私有化儡湾,禁止外部設(shè)置特恬;這樣 Java 中 debug 屬性對(duì)應(yīng)的方法 getDebug() 是公有的,而對(duì)應(yīng)的 setDebug() 是私有的徐钠。

  • 代碼第3??行添加 @JvmOverloads 注解后癌刽,JVM 編譯器會(huì)生成對(duì)個(gè)版本的 setLogger 方法提供給 Java 調(diào)用,因?yàn)?Java 中不能給方法參數(shù)設(shè)置默認(rèn)值尝丐。這也是 Kotlin 和 Java 中思想不同點(diǎn)之一显拜,在編寫 kotlin 代碼時(shí),使用重載的地方要盡量使用 默認(rèn)參數(shù) 思想替換爹袁。“@JvmOverloads相關(guān)知識(shí)傳送門”

  • 代碼第4??行添加 @JvmStatic 注解后远荠,在 Java 中可以通過 OkLogger. setLogger()(類名.函數(shù)名) 來調(diào)用。“@JvmStatic相關(guān)知識(shí)傳送門”

  • 代碼第5??行失息,通過設(shè)置默認(rèn)參數(shù)的思想譬淳,達(dá)到函數(shù)重載的目的。

  • 代碼第6??行 throwable?.printStackTrace()盹兢,只有當(dāng) throwable 不為 null 時(shí)才會(huì)執(zhí)行后面的 printStackTrace() 方法邻梆。“?. 知識(shí)傳送門”

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市绎秒,隨后出現(xiàn)的幾起案子浦妄,更是在濱河造成了極大的恐慌,老刑警劉巖替裆,帶你破解...
    沈念sama閱讀 218,858評(píng)論 6 508
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件校辩,死亡現(xiàn)場離奇詭異,居然都是意外死亡辆童,警方通過查閱死者的電腦和手機(jī)宜咒,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,372評(píng)論 3 395
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來把鉴,“玉大人故黑,你說我怎么就攤上這事⊥タ常” “怎么了场晶?”我有些...
    開封第一講書人閱讀 165,282評(píng)論 0 356
  • 文/不壞的土叔 我叫張陵,是天一觀的道長怠缸。 經(jīng)常有香客問我诗轻,道長,這世上最難降的妖魔是什么揭北? 我笑而不...
    開封第一講書人閱讀 58,842評(píng)論 1 295
  • 正文 為了忘掉前任扳炬,我火速辦了婚禮吏颖,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘恨樟。我一直安慰自己半醉,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,857評(píng)論 6 392
  • 文/花漫 我一把揭開白布劝术。 她就那樣靜靜地躺著缩多,像睡著了一般。 火紅的嫁衣襯著肌膚如雪养晋。 梳的紋絲不亂的頭發(fā)上衬吆,一...
    開封第一講書人閱讀 51,679評(píng)論 1 305
  • 那天,我揣著相機(jī)與錄音匙握,去河邊找鬼咆槽。 笑死,一個(gè)胖子當(dāng)著我的面吹牛圈纺,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播麦射,決...
    沈念sama閱讀 40,406評(píng)論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼蛾娶,長吁一口氣:“原來是場噩夢(mèng)啊……” “哼!你這毒婦竟也來了潜秋?” 一聲冷哼從身側(cè)響起蛔琅,我...
    開封第一講書人閱讀 39,311評(píng)論 0 276
  • 序言:老撾萬榮一對(duì)情侶失蹤,失蹤者是張志新(化名)和其女友劉穎峻呛,沒想到半個(gè)月后罗售,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 45,767評(píng)論 1 315
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡钩述,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,945評(píng)論 3 336
  • 正文 我和宋清朗相戀三年寨躁,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片牙勘。...
    茶點(diǎn)故事閱讀 40,090評(píng)論 1 350
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡职恳,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出方面,到底是詐尸還是另有隱情放钦,我是刑警寧澤,帶...
    沈念sama閱讀 35,785評(píng)論 5 346
  • 正文 年R本政府宣布恭金,位于F島的核電站操禀,受9級(jí)特大地震影響,放射性物質(zhì)發(fā)生泄漏横腿。R本人自食惡果不足惜颓屑,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,420評(píng)論 3 331
  • 文/蒙蒙 一辙培、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧邢锯,春花似錦扬蕊、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,988評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至蒂培,卻和暖如春再愈,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背护戳。 一陣腳步聲響...
    開封第一講書人閱讀 33,101評(píng)論 1 271
  • 我被黑心中介騙來泰國打工翎冲, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人媳荒。 一個(gè)月前我還...
    沈念sama閱讀 48,298評(píng)論 3 372
  • 正文 我出身青樓抗悍,卻偏偏與公主長得像,于是被迫代替她去往敵國和親钳枕。 傳聞我的和親對(duì)象是個(gè)殘疾皇子缴渊,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,033評(píng)論 2 355