栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > 后端开发 > Java

Java注解

Java 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

Java注解

注解

注解入门

Annotation是从JDK5.0开始引入的新技术.

Annotation的作用:

不是程序本身,可以对程序作出解释、(这一点和注释(comment)没什么区别)

可以被其他程序(比如:编译器等)读取.

Annotation的格式:

注解是以"@注释名"在代码中存在的,还可以添加一些参数值,例 如:@SuppressWarnings(value=“unchecked”).

Annotation在哪里使用?

可以附加在package,class,method,tield 等上面,相当于给他们添加了额外的辅助信息, 我们可以通过反射机制编程实现对这些元数据的访问

内置注解

@override :定义在 java.lang.Override 中,此注释只适用于修辞方法 ,表示一个方法声明打算 重写超类中的另一 个方法声明.@Deprecated:定义在java.lang.Deprecated中,此注释可以用于修辞方法,属性,类,表示不 鼓励程序员使用这样的元素,通常是因为它很危险或者存在更好的选择.@suppressWarnings:定义在java.lang.SuppressWarnings中,用来抑制编译时的警告信息. 口 与前两个注释有所不同,你需要添加一个参数才能正确使用,这此参数都是已经定义好了的, 我们选择性的使用就好了—@SuppressWarnings(“all”)
@SuppressWarnings(“unchecked”)
@SuppressWarnings(value=(“unchecked”,“deprecation”})

元注解

元注解的作用就是负责注解其他注解,Java定义了4个标准的meta-annotation类型,他们被用来 提供对其他annotation类型作说明这些类型和它们所支持的类在java.lang.annotation包中可以找到.( @Target , @Retention, @documented ,@Inherited >

@Target:用于描述注解的使用范围(即:被描述的注解可以用在什么地方)@Retention :表示需要在什么级别保存该注释信息,用于描述注解的生命周期

(SOURCE < CLASS < RUNTIME) @document:说明该注解将被包含在jiavadoc中@lnherited:说明子类可以继承父类中的该注解

  package com.cjp;
    
    import java.lang.annotation.*;
    
    //测试元注解
    @MyAnnotation
    public class Test02 {
        @MyAnnotation
        public void test(){
    
        }
    }
    //定义一个注解
    //@Target ,表示我们的注解可以用在哪些地方。
    @Target(value = {ElementType.METHOD,ElementType.TYPE})
    //Retention表示我们的注解在什么地方还有效
    @Retention(value = RetentionPolicy.RUNTIME)
    //@documented表示是否将我们的注解生成在JAVAdoc中
    @documented
    //@Inherited表示子类可以继承父类
    @Inherited
     @interface  MyAnnotation{
    
    }

自定义注解

使用 @interface自定义注解时,自动继承 了java.lang.annotation.Annotation接口 2分析:

@interface用来声明一个注解,格式:public @ interface 注解名{定义内容}

其中的每一个方法实际上是声明了一个配置参数.

方法的名称就是参数的名称. 、 返回值类型就是参数的类型(返回值只能是基本类型,Class, String,enum).

可以通过default来声明参数的默认值

如果只有一个参数成员, 一般参数名为value

注解元素心须要有值,我们定义注解元素时,经常使用空字符串,O作为默认值.

package com.cjp;

import java.lang.annotation.*;

//自定义注解
public class Test03 {
//有默认值注解可以显示赋值,没有默认值就必须给注解赋值
@MyAnnotation2(name = “cjp”,school = {“林科大”,“螺蛳粉职业技术学院”})

  public void test(){
            
        }
        @MyAnnotation3("cjp")
        public void test1(){
            
        }
    }
    
    @Target({ElementType.METHOD,ElementType.TYPE})
    @Retention(RetentionPolicy.RUNTIME)
    @interface MyAnnotation2{
        //注解的参数  :参数类型 + 参数名();
        String name() default "";
        int age() default 0;
        int id()default -1;//如果默认值为-1,则代表不存在
        String[] school()default {"清华","北大"};
    }
    
    @Target({ElementType.METHOD,ElementType.TYPE})
    @Retention(RetentionPolicy.RUNTIME)
    @interface MyAnnotation3{
        String value();
        
    }
转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/760560.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号