Kotlinのスコープ関数の注意点とデメリットを知ろう!初心者がやりがちな落とし穴を解説
生徒
「先生、Kotlinのスコープ関数って便利ですよね!でも、使っててちょっと混乱することがあるんです…」
先生
「たしかに、let・run・apply・also・withは便利ですが、注意しないと逆にわかりづらくなることもあるんですよ。」
生徒
「えっ!?便利なだけじゃないんですか?」
先生
「そうなんです。今日はKotlinのスコープ関数の注意点とデメリットをやさしく解説しますね!」
1. スコープ関数とは?基本をサクッとおさらい
スコープ関数(Scope Functions)とは、特定のオブジェクト(データ)に対して、「ある一定の範囲(スコープ)内だけで一時的に処理を実行する」ための便利な仕組みです。
例えば、料理で例えると「まな板の上に食材を置いて、その上だけでトントンと切ったり味付けしたりするイメージ」です。わざわざ別の場所に移動させずに、その場でパパッと処理を済ませられるのがメリットです。
Kotlinには、主に以下の5つのスコープ関数が用意されています。
let(レット)run(ラン)apply(アプライ)also(オールソー)with(ウィズ)
プログラミング未経験の方でもイメージしやすいように、簡単なサンプルコードを見てみましょう。
fun main() {
// 1. スコープ関数を使わない書き方(普通に変数を作る)
val message = "こんにちは"
println(message.length)
println(message.reversed())
// 2. スコープ関数(let)を使った書き方
// "Hello"という文字列に対して、その場(ブロック内)だけで処理をする
"Hello".let {
println(it.length) // itは"Hello"を指します
println(it.reversed())
}
}
スコープ関数を使うと、「このオブジェクトに対して、今からこれだけの処理をまとめてやりますよ」という範囲が明確になり、コードがスッキリと整理されます。しかし、それぞれ「戻り値」や「オブジェクトの呼び方」に微妙な違いがあるため、使い分けが重要になってきます。
2. 使いすぎると読みづらくなる
スコープ関数は便利ですが、何でもかんでも使うのはおすすめできません。
理由は、誰が何をしているのかが分かりにくくなるからです。
たとえば、itやthisが続くと、読み手は「どのオブジェクトの話?」と混乱してしまいます。
val user = User("Taro", 20).apply {
println(name)
}.also {
println(it.age)
}.let {
println(it.name.reversed())
}
このようにスコープ関数を連続で使うと、コードの意味を追うのが大変になります。
3. 戻り値の違いに注意しよう
スコープ関数はそれぞれ戻り値(関数の結果)が違います。
let:ラムダ式の結果run:ラムダ式の結果apply:オブジェクト自体(this)also:オブジェクト自体(it)with:ラムダ式の結果
この違いを理解せずに使うと、想定と違う値が返ってくることがあります。
val result = "kotlin".apply {
uppercase()
}
println(result)
kotlin
この例ではuppercase()の結果が返ると思いきや、実際には元の文字列"kotlin"がそのまま返ります。
Kotlinを基礎からしっかり学びたい人や、 Java経験を活かしてモダンな言語にステップアップしたい人には、 定番の入門書がこちらです。
基礎からわかるKotlinをAmazonで見る※ Amazon広告リンク
4. 使い分けが難しい
初心者のうちは「letとalsoの違いがわからない」というような混乱が起きがちです。
実際、itを使う点では両者は似ています。でも、letは処理結果を返し、alsoは元のオブジェクトを返します。
val name = "suzuki"
val result1 = name.let {
it.uppercase()
}
val result2 = name.also {
it.uppercase()
}
result1 → SUZUKI
result2 → suzuki
こうした違いに気づかないと、「なぜ思った結果にならないのか」が分からなくなってしまいます。
5. ネスト(入れ子)しすぎると危険
スコープ関数を入れ子(ネスト)にしすぎると、初心者にとっては地獄のように読みにくくなります。
user?.let {
it.address?.apply {
this.city?.run {
println(this.uppercase())
}
}
}
最初は便利でも、ネストが増えると「今どこを操作してるの?」と迷子になります。
できるだけvalで区切って書くようにしましょう。
6. 自分以外の人が読めるか考えよう
プログラミングは他の人も読むものです。特にチーム開発では、コードの読みやすさはとても重要です。
スコープ関数を使いすぎると、「カッコが多くて読めない」「thisとitが混在してて混乱」という状態になりやすいです。
自分では理解できても、あとで見返すと「これ何してるんだっけ?」と分からなくなることもあります。
7. 本当に使うべき場面か見極めよう
スコープ関数はあくまでコードを簡潔にするための道具です。
でも、どんな処理でもスコープ関数で書こうとすると、逆にわかりにくいコードになってしまいます。
・値を一時的に加工する
・オブジェクトの初期設定を簡単に書く
・ログを挟みたい
このような明確な目的があるときにだけ、スコープ関数を使うようにしましょう。