10
4

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?

More than 3 years have passed since last update.

【Kotlin】トップレベル宣言

Last updated at Posted at 2020-06-16

先日、GithubでKotlinのコードを眺めていたら以下のような記述を見かけました。

package hoge.huga

class Hoge {
    ...
}

private const val HUGA = "Huga"

定数がパッケージの宣言と同じレベルに宣言されています。
初めてみた書き方だったので色々調べてみました。

#トップレベル宣言 (Top-level Declarations)
Javaではトップレベルに宣言できるのはクラスのみですが、Kotlinではクラスの他に

・関数
・プロパティ
・型エイリアス

なども宣言することができます。

上記のように、パッケージのトップレベル(パッケージレベルとも)に関数やプロパティを定義することを**トップレベル宣言(Top-level Declarations)**といいます。

トップレベルに宣言されたものは、クラスインスタンスを経由せずに使用することができます。

Companion Objectとの使い分け

ところでKotlinにはstatic修飾子がありません。
代わりにKotlinではトップレベルに宣言するほかに、companion objectを使用することが代替手段として挙げられます。

両者の大きな違いとして、トップレベル関数からはクラスのprivateメンバにアクセスすることができません。
そのため、ファクトリーメソッドのようにクラス内部にアクセスしたい場合には、companion objectを使用します。

バイトコードとしての差など、より詳しい違いについては、こちらの記事が非常に参考になりました。

おまけ:Javaから見たトップレベル宣言

KotlinとJavaは相互利用することが可能ですが、以下のように.ktファイルに宣言された関数をJavaから呼び出す場合、どうなるのでしょうか。

Hoge.kt
package com.hoge

fun printHoge() {
    println("Hoge")
}

Javaにおいて全てのメソッドはクラスに属していなければならないため、Hoge.ktというファイル名から自動的に生成されたHogeKtクラスを介して呼び出す必要があるようです。

Huga.java
import com.hoge.HogeKt;

public class Huga {
    public static void main(String args[]) {
        HogeKt.printHoge();
    }
}

ファイル名から自動生成されるクラスにはJvmNameアノテーションを使用して任意の名前を指定することができます。

Hoge.kt
@file:JvmName("Hoge")
package com.hoge

fun printHoge() {
    println("Hoge")
}
Huga.java
import com.hoge.Hoge;

public class Huga {
    public static void main(String args[]) {
        Hoge.printHoge();
    }
}
10
4
0

Register as a new user and use Qiita more conveniently

  1. You get articles that match your needs
  2. You can efficiently read back useful information
  3. You can use dark theme
What you can do with signing up
10
4

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?