Oprócz tego, co sugerowali inni, radzę napisać od podstaw dostosowaną adnotację i jej procesor, aby zobaczyć, jak działa adnotacja.
Na przykład we własnym napisałem adnotację, aby sprawdzić, czy metody nie są przeciążone w czasie kompilacji.
Najpierw utwórz adnotację o nazwie Overload
. Ta adnotacja jest stosowana do metody, więc dodaję do niej adnotację@Target(value=ElementType.METHOD)
package gearon.customAnnotation;
import java.lang.annotation.ElementType;
import java.lang.annotation.Target;
@Target(value=ElementType.METHOD)
public @interface Overload {
}
Następnie utwórz odpowiedni procesor do obsługi elementów opisanych za pomocą zdefiniowanej adnotacji. W przypadku metody z adnotacją przez @Overload
jej podpis musi pojawić się więcej niż jeden raz. Lub błąd zostanie wydrukowany.
package gearon.customAnnotation;
import java.util.HashMap;
import java.util.Map.Entry;
import java.util.Set;
import javax.annotation.processing.AbstractProcessor;
import javax.annotation.processing.RoundEnvironment;
import javax.annotation.processing.SupportedAnnotationTypes;
import javax.lang.model.element.Element;
import javax.lang.model.element.TypeElement;
import javax.tools.Diagnostic.Kind;
@SupportedAnnotationTypes("gearon.customAnnotation.Overload")
public class OverloadProcessor extends AbstractProcessor{
@Override
public boolean process(Set<? extends TypeElement> annotations, RoundEnvironment roundEnv) {
HashMap<String, Integer> map = new HashMap<String, Integer>();
for(Element element : roundEnv.getElementsAnnotatedWith(Overload.class)){
String signature = element.getSimpleName().toString();
int count = map.containsKey(signature) ? map.get(signature) : 0;
map.put(signature, ++count);
}
for(Entry<String, Integer> entry: map.entrySet()){
if(entry.getValue() == 1){
processingEnv.getMessager().printMessage(Kind.ERROR, "The method which signature is " + entry.getKey() + " has not been overloaded");
}
}
return true;
}
}
Po spakowaniu adnotacji i jej przetworzeniu do pliku jar, utwórz klasę @Overload
i użyj javac.exe do jej skompilowania.
import gearon.customAnnotation.Overload;
public class OverloadTest {
@Overload
public static void foo(){
}
@Overload
public static void foo(String s){
}
@Overload
public static void nonOverloadedMethod(){
}
}
Ponieważ w nonOverloadedMethod()
rzeczywistości nie został przeciążony, otrzymamy dane wyjściowe jak poniżej: