Groovy - Аннотации

Аннотации - это форма метаданных, в которых они предоставляют данные о программе, которая не является частью самой программы. Аннотации не имеют прямого влияния на работу аннотируемого кода.

Аннотации в основном используются по следующим причинам -

  • Information for the compiler - Аннотации могут использоваться компилятором для обнаружения ошибок или подавления предупреждений.

  • Compile-time and deployment-time processing - Программные инструменты могут обрабатывать аннотационную информацию для создания кода, файлов XML и т. Д.

  • Runtime processing - Некоторые аннотации доступны для изучения во время выполнения.

В Groovy базовая аннотация выглядит следующим образом:

@interface - символ знака (@) указывает компилятору, что нижеследующее является аннотацией.

Аннотация может определять элементы в the form методов без тел и необязательного значения по умолчанию.

Аннотации могут применяться к следующим типам -

Тип строки

Пример аннотации для строки приведен ниже -

@interface Simple { 
   String str1() default "HelloWorld"; 
}

Тип перечисления

enum DayOfWeek { mon, tue, wed, thu, fri, sat, sun } 
@interface Scheduled {
   DayOfWeek dayOfWeek() 
}

Тип класса

@interface Simple {} 
@Simple 
class User {
   String username
   int age
}
 
def user = new User(username: "Joe",age:1); 
println(user.age); 
println(user.username);

Значения элементов аннотации

Когда используется аннотация, необходимо установить по крайней мере все элементы, не имеющие значения по умолчанию. Пример приведен ниже. Когда Пример аннотации используется после того, как он был определен, ему необходимо присвоить значение.

@interface Example {
   int status() 
}

@Example(status = 1)

Параметры аннотации закрытия

Хорошей особенностью аннотаций в Groovy является то, что вы также можете использовать замыкание в качестве значения аннотации. Поэтому аннотации могут использоваться с самыми разными выражениями.

Пример приведен ниже. Аннотация Только если создается на основе значения класса. Затем аннотация применяется к двум методам, которые отправляют разные сообщения переменной результата в зависимости от значения числовой переменной.

@interface OnlyIf {
   Class value() 
}  

@OnlyIf({ number<=6 }) 
void Version6() {
   result << 'Number greater than 6' 
} 

@OnlyIf({ number>=6 }) 
void Version7() {
   result << 'Number greater than 6' 
}

Мета-аннотации

Это довольно полезная функция аннотаций в Groovy. Бывают случаи, когда у вас может быть несколько аннотаций для метода, как показано ниже. Иногда использование нескольких аннотаций может вызвать затруднения.

@Procedure 
@Master class 
MyMasterProcedure {}

В таком случае вы можете определить метааннотацию, которая объединяет несколько аннотаций вместе, и применить метааннотацию к методу. Итак, для приведенного выше примера вы можете сначала определить коллекцию аннотаций с помощью AnnotationCollector.

import groovy.transform.AnnotationCollector
  
@Procedure 
@Master 
@AnnotationCollector

Как только это будет сделано, вы можете применить к методу следующий метааннотатор -

import groovy.transform.AnnotationCollector
  
@Procedure 
@Master 
@AnnotationCollector
  
@MasterProcedure 
class MyMasterProcedure {}