Maison > Java > javaDidacticiel > le corps du texte

[java] Utilisation d'un didacticiel détaillé sur les annotations personnalisées

php是最好的语言
Libérer: 2018-08-06 11:42:21
original
1907 Les gens l'ont consulté

Annotations

Lorsque vous utilisez @interface pour personnaliser les annotations, l'interface java.lang.annotation.Annotation est automatiquement héritée et d'autres détails sont automatiquement complétés par le compilateur. Lors de la définition d'annotations, vous ne pouvez pas hériter d'autres annotations ou interfaces. @interface est utilisé pour déclarer une annotation, et chaque méthode déclare en fait un paramètre de configuration. Le nom de la méthode est le nom du paramètre et le type de valeur de retour est le type du paramètre (le type de valeur de retour ne peut être que des types de base, Class, String ou enum). Vous pouvez déclarer la valeur par défaut d'un paramètre via default.
                                                                                                      dehors out out‐ through out out  ‐ off‐outward ‐ ‐‐ ‐ ‐ ‐ ‐ ‐ ‐ 1. Tous les types de données de base (int, float, boolean, byte, double, char, long, short)
​​ ​ 2.Type de chaîne
​ ​ 3.Type de classe
​ ​ 4.Type d'enum
​ ​ ​ 5.Type d'annotation
​ ​ 6. Tous les éléments ci-dessus Tableau de type


Saisir directement le code :

Utiliser la classe annotée

import java.lang.annotation.Documented;
import java.lang.annotation.ElementType;
import java.lang.annotation.Retention;
import java.lang.annotation.RetentionPolicy;
import java.lang.annotation.Target;
 
/**
 * 定义一个注解
 */
@Target(ElementType.METHOD) // 这是一个对方法的注解,还可以是包、类、变量等很多东西
@Retention(RetentionPolicy.RUNTIME) // 保留时间,一般注解就是为了框架开发时代替配置文件使用,JVM运行时用反射取参数处理,所以一般都为RUNTIME类型
@Documented // 用于描述其它类型的annotation应该被作为被标注的程序成员的公共API,因此可以被例如javadoc此类的工具文档化
public @interface OneAnnotation {
 
	// 定义注解的参数,类型可以为基本类型以及String、Class、enum、数组等,default为默认值
	String parameter1() default "";
	int parameter2() default -1;
Copier après la connexion

Extraire les paramètres d'annotation

/**
 * 一个用到了自定义的注解的类
 */
public class OneClass {
	
	@OneAnnotation(parameter1="YES", parameter2=10000)
	public void oneMethod () {
	}
Copier après la connexion

Test résultats :

import java.lang.reflect.Method;
 
 
public class TestThis {
 
	public static void main(String[] args) throws Exception {
		// 提取到被注解的方法Method,这里用到了反射的知识
		Method method = Class.forName("OneClass").getDeclaredMethod("oneMethod");
		// 从Method方法中通过方法getAnnotation获得我们设置的注解
		OneAnnotation oneAnnotation = method.getAnnotation(OneAnnotation.class);
		
		// 得到注解的俩参数
		System.out.println(oneAnnotation.parameter1());
		System.out.println(oneAnnotation.parameter2());
	}
Copier après la connexion
OUI

10000

Articles associés :

Annotations personnalisées Java

Java tutoriel d'annotation et annotations de définition personnalisées

Vidéos associées :

Analyse complète des annotations Java

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Étiquettes associées:
source:php.cn
Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn
Tutoriels populaires
Plus>
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal