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

注解和反射01:什么是注解,内置注解,元注解

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

注解和反射01:什么是注解,内置注解,元注解

文章目录
  • 什么是注解
    • 一:Annotation的作用:
    • 二:Annotation的格式
    • 三:Annotation在哪里使用?
  • 内置注解
  • 元注解
    • 自定义一个注释类
  • 自定义注解
  • 喜欢技术的,一起进群交流学习吧!!!

什么是注解

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

一:Annotation的作用:

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

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

二:Annotation的格式

注释是以“@注释名”在代码中存在,还可以添加一些参数值

三:Annotation在哪里使用?

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

内置注解

@Override: 定义在java.lang.Override中,此注释只适用于修辞方法﹐表示

一个方法声明打算重写超类中的另一个方法声明.

@Deprecated: 定义在java.lang.Deprecated中,此注释可以用于修辞方法.

属性,类,表示不鼓励程序员使用这样的元素,通常是因为它很危险或者存在

更好的选择.

@SuppressWarnings: 定义在java.lang.SuppressWarnings中,用来抑制

编译时的警告信息 .与前两个注释有所不同,你需要添加一个参数才能正确

使用这些参数都是已经定义好了的,我们选择性的使用就好了.

√@SuppressWarnings(“all”)

√ @SuppressWarnings(“unchecked”)

√@SuppressWarnings(value={“unchecked” ,“deprecation”})

√等等…

import java.util.ArrayList;
import java.util.List;

//什么是注解
//@Deprecated已废弃
public class Demo1 extends Object{
    @Override //重写的注解
    public String toString() {
        return super.toString();
    }

 //Deprecated 过时的,不推荐程序员使用,但可以使用,或者存在更好的方式
    @Deprecated
    public static void test(){
        System.out.println("Hello World! I'm coming!!!");
    }
    //test02()没有加@SuppressWarnings("all"),会报警告信息
    //Method 'test02()' is never used 
    //Variable 'list' is never used
    public void test02(){
        List list = new ArrayList();
    }
    @SuppressWarnings("all")
    //@SuppressWarnings("all") 警告镇压,平时写代码不建议用,
    // 因为警告可以帮助我们识别程序中的一些错误,除非你看的真心烦了
    public void test3(){
        List list = new ArrayList();
    }
    public static void main(String[] args){
        test();
    }
}

元注解

元注解的作用就是负责注解其他注解,Java定义了4个标准的

meta-annotation类型,他们被用来提供对其他annotation类型作说明.

这些类型和它们所支持的类在java.lang.annotation包中可以找到.(@Target

, @Retention ,@documented , @lnherited )

@Target : 用于描述注解的使用范围(即:被描述的注解可以用在什么地方,

比如是在类,方法还是在构造器上使用)

@Retention : 表示需要在什么级别保存该注释信息﹐用于描述注解的生命

周期(SOURCE(源码级别)

@document : 说明该注解将被包含在javadoc中

@Inherited : 说明子类可以继承父类中的该注解

自定义一个注释类

注解和反射04:自定义注解

自定义注解

@Target()作用域
让它可以在类和方法上定义
@Target({ElementType.TYPE,ElementType.METHOD})

@Target定义了注解可以在方法上使用
定义了参数不写参数便会报错


import java.lang.annotation.ElementType;
import java.lang.annotation.Retention;
import java.lang.annotation.RetentionPolicy;
import java.lang.annotation.Target;

//自定义注解
public class Demo3 {
    //注释可以显示赋值,如果没有默认值,我们就必须给注解赋值
    @MyAnnotation2(name="老酒",age = 18)
    public void test(){
    }
}
@Target({ElementType.TYPE,ElementType.METHOD})
@Retention(RetentionPolicy.RUNTIME)
@interface MyAnnotation2{
    //注解的参数 :参数类型 + 参数名();
    String name();
    //String name() default "";
    int age() default 0;
    int id() default -1;// 如果默认值为-1,代表不存在,indexof,如果找不到就返回-1
    String[] schools() default {"清华","北大"};
}

区别
name()和value()的区别

喜欢技术的,一起进群交流学习吧!!!

转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/305930.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

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

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