# enum

* 타입을 담는 클래스. 열거형 클래스라고도 한다.

```java
//java
enum Color {
    RED(0xFF0000), GREEN(0x00FF00), BLUE(0x0000FF);

    int rgb;
    Color(int color) {
        rgb = color;
    }
}

for(Color color : Color.values()) {
    System.out.println(color);
}
// RED,GREEN,BLUE
```

```kotlin
//kotlin
enum class Color(val rgb: Int) {
    RED(0xFF0000),
    GREEN(0x00FF00),
    BLUE(0x0000FF);
}

for(color: Color in Color.values()) {
    println(color)
}
//RED,GREEN,BLUE

//코틀린에선 enum class의 생성자부분을 클래스헤더와 같이 작성할 수 있어 코드길이를 줄일 수 있다.

val red: Color = Color.valueOf("RED")
val green: Color = Color.GREEN
val colorList: Array<Color> = Color.values()
```

```kotlin
//kotlin
enum class Color(val rgb: Int) {
    RED(0xFF0000),
    GREEN(0x00FF00),
    BLUE(0x0000FF);  

    fun rgb() {
        //...
    }

    //enum 클래스 안에서 멤버함수를 정의한다면 마지막 항목 끝에 자바에서 처럼 ; 을 붙여주어야 한다.

}
```


---

# Agent Instructions: Querying This Documentation

If you need additional information that is not directly available in this page, you can query the documentation dynamically by asking a question.

Perform an HTTP GET request on the current page URL with the `ask` query parameter:

```
GET https://gold.gitbook.io/kotlin/class/enum.md?ask=<question>
```

The question should be specific, self-contained, and written in natural language.
The response will contain a direct answer to the question and relevant excerpts and sources from the documentation.

Use this mechanism when the answer is not explicitly present in the current page, you need clarification or additional context, or you want to retrieve related documentation sections.
