官术网_书友最值得收藏!

Annotations

Annotations are a way to attach meta info to your code (such as documentation, configuration, and others).

Let's look at the following example code:

annotation class Tasty

An annotation itself can be annotated to modify its behavior:

@Target(AnnotationTarget.CLASS)
@Retention(AnnotationRetention.RUNTIME)
annotation class Tasty

In this case, the Tasty annotation can be set on classes, interfaces, and objects, and it can be queried at runtime.

For a complete list of options, check the Kotlin documentation.

Annotations can have parameters with one limitation, they can't be nullable:

@Target(AnnotationTarget.CLASS)
@Retention(AnnotationRetention.RUNTIME)
annotation class Tasty(val tasty:Boolean = true)

@Tasty(false)
object ElectricOven : Oven {
override fun process(product: Bakeable) {
println(product.bake())
}
}

@Tasty
class CinnamonRoll : Roll("Cinnamon")

@Tasty
interface Fried {
fun fry(): String
}

To query annotation values at runtime, we must use the reflection API (kotlin-reflect.jar must be in your classpath):

fun main(args: Array<String>) {
val annotations: List<Annotation> = ElectricOven::class.annotations

for (annotation in annotations) {
when (annotation) {
is Tasty -> println("Is it tasty? ${annotation.tasty}")
else -> println(annotation)
}
}
}
主站蜘蛛池模板: 肥城市| 新田县| 白银市| 犍为县| 长宁县| 厦门市| 沿河| 兰州市| 宁都县| 时尚| 通榆县| 墨江| 库伦旗| 禹州市| 金沙县| 墨脱县| 河西区| 义乌市| 全南县| 龙井市| 德安县| 固阳县| 赤城县| 定边县| 安达市| 天长市| 依兰县| 大名县| 靖远县| 乐平市| 怀远县| 大同市| 湟源县| 绵竹市| 通山县| 舒城县| 德安县| 昭苏县| 阿克陶县| 扎囊县| 凭祥市|