9cubed
ブログ | PHP | JavaScript | TypeScript | Vue.js | Laravel | Tailwind | Vite | Python | MariaDB | SQLite | Node.js | Linux | PowerShell | Docker | Git | Web | その他
< 前の記事

Kotlin - クラス - 基本

次の記事 >

Kotlin - クラス - コンストラクタ

Kotlin

Kotlin - クラス - init ブロック

公開日:2019-11-21
更新日:2019-11-21

1. 概要

init ブロックについてです。


2. init ブロック

クラス内にある init ブロックは、クラスのインスタンス生成時に、上から順に実行されます。
コンストラクタやプロパティの初期化などで使用できます。

init ブロックで初期化していないプロパティにアクセスした場合はコンパイルエラーになりますが、 メソッドから初期化されていないプロパティにアクセスした場合はエラーにならないため要注意です。

class Test() {
    init {
        println("init-1")
        //println(this.value1) // value1 が初期化されていないためコンパイルエラー
        println(add()) // 0。要注意。この段階では value1 が初期化されていないが、エラーにならない。
    }

    val value1:Int = 100
    val value2:Int = 200

    init {
        println("init-2")
        println(this.value1) // 100
        println(this.value2) // 200
    }

    fun add():Int {
        return value1 + value2
    }

    init {
        println("init-3")
        println(add()) // 300
    }
}

fun main() {
    val obj = Test()
}

プロパティごとに init を付けて初期化することもできます。
この場合、プロパティ定義時に初期化しなくてもエラーになりません。
class Test() {
    val value1:Int
    init {
        value1 = 100
    }

    val value2:Int
    init {
        value2 = 200
    }
}

fun main() {
    val obj = Test()
    println(obj.value1) // 100
    println(obj.value2) // 200
}

< 前の記事

Kotlin - クラス - 基本

次の記事 >

Kotlin - クラス - コンストラクタ

YouTube X

新着一覧

  • async、awaitJavaScript
  • Promise についてJavaScript
  • パッケージの管理Node.js
  • v-model(双方向バインディング)Vue.js
  • VS Code で GitHub を使ったソース管理Git
  • computed(再計算)Vue.js
  • watchDebounced(値の監視)Vue.js
  • watch(値の監視)Vue.js
  • change イベントVue.js
  • v-memoVue.js

アーカイブ

  • 2026/03
  • 2026/02
  • 2026/01
  • 2025/12
  • 2025/11
  • 2025/10
  • 2025/09
  • 2025/08
  • /00

以前のカテゴリー一覧

  • CakePHP3
  • CentOS7
  • HTML・CSS・JavaScript
  • Haskell
  • JavaScript
  • Kotlin
  • Laravel5
  • PHP
  • Python
  • Ruby
  • RubyOnRails5
  • TypeScript
  • Vue.js
  • Webサーバ講座
  • Webプログラミング講座
  • jQuery
  • linux
  • パソコン講座
  • ブログ
  • プログラミング講座
  • メモ帳作成講座
  • 数学

Copyright © 9cubed. All Rights Reserved.

プライバシーポリシー 利用規約
▲