Kotlinでオブジェクト(object)の動作確認


objectを使っていくつか遊びがてら実験してみた。オブジェクトに関してもやもやしていたが少しだけつかめてきた気がする。



companion object でシングルトンの動作確認

Kotlinでcompanion objectを使ってJavaのStatic変数のような動作を行ってみた。次のHogeクラスはシングルトンパターンの基本的な形である。

class Hoge {
    companion object{
        var counter:Int = 0
    }

    fun countUp():Int {
        return counter++
    }
}

fun main() {


    val hoge1 = Hoge()

    println("hoge1 : ${hoge1.countUp()}")
    println("hoge1 : ${hoge1.countUp()}")
    println("hoge1 : ${hoge1.countUp()}")
    println("hoge1 : ${hoge1.countUp()}")

    val hoge2 = Hoge()
    println("hoge2 : ${hoge2.countUp()}")
    println("hoge2 : ${hoge2.countUp()}")
    println("hoge2 : ${hoge2.countUp()}")
    println("hoge1 : ${hoge1.countUp()}")

}


実行結果は次の通りとなる。確かにcompanion objectで囲まれた変数counterはインスタンスが一つだけとなっているようだ。

hoge1 : 0
hoge1 : 1
hoge1 : 2
hoge1 : 3
hoge2 : 4
hoge2 : 5
hoge2 : 6
hoge1 : 7



メソッドの関数オブジェクト

次のプログラム内のように、関数自体をオブジェクトとして扱う使うことが出来る。ただし、Hogeクラスのインスタンスを生成する必要がある。

class Hoge {
    var counter:Int = 0

    fun countUp():Int {
        return counter++
    }
}

fun main() {
    
    val hoge = Hoge()
    val countUp = hoge::countUp

    println("countUp1 : ${countUp()}")
    println("countUp1 : ${countUp()}")
    println("countUp1 : ${countUp()}")
    println("countUp1 : ${countUp()}")

}


実行結果は次の通り。
countUp1 : 0
countUp1 : 1
countUp1 : 2
countUp1 : 3



インタフェースとオブジェクトの組み合わせ

次のプログラムはOkHttpのCallbackで使うようなパターンだ。

interface Hoge {
    var counter:Int
    fun countUp():Int
}

val hoge = object:Hoge {
    init {
        counter = 0
    }

    override var counter: Int
        get() {
            println("counter ゲット ($field)")
            return field
        }
        set(value) {
            println("counter セット (${value})")
            field = value
        }

    override fun countUp(): Int {
        counter++
        return counter
    }

}

fun main() {
    
    hoge.countUp()
    hoge.countUp()
    hoge.countUp()
    hoge.countUp()
    hoge.countUp()

}


実行結果は次の通りとなる。

counter セット (0)
counter ゲット (0)
counter セット (1)
counter ゲット (1)
counter ゲット (1)
counter セット (2)
counter ゲット (2)
counter ゲット (2)
counter セット (3)
counter ゲット (3)
counter ゲット (3)
counter セット (4)
counter ゲット (4)
counter ゲット (4)
counter セット (5)
counter ゲット (5)


参考