JAVA自定义注解使用

网友投稿 260 2022-09-06

JAVA自定义注解使用

说到注解 在java中我们经常会看到@Override,@Deprecated,@SuppressWarnings这些注解。这些都是JDK自带的注解

关于自定义注解:

1.使用@interface关键字定义注解

3.成员可以使用default指定一个默认值

4.如果只有一个成员  成员名必须为value().使用时 可以忽略=号

元注解:

@Target  表示注解的作作用域。ElementType参数有

RetentionPolicy.SOURCE 源码注解(注解将被编译器丢弃)RetentionPolicy.CLASS 编译时注解(注解在class文件可用,但会被VM丢弃)RetentionPolicy.RUNTIME 运行时注解(运行时保留注解,因此可以使用java反射机制读取注解信息)

@Inherited 允许子类继承父类的注解

@Documented将注解包含在javadoc中

自定义注解实战

项目需求

我们分别为表名和字段名新建注解

Table注解  作用域在类@Target(ElementType.TYPE),生命周期为@Retention(RetentionPolicy.RUNTIME)

package com.susu;import java.lang.annotation.ElementType;import java.lang.annotation.Retention;import java.lang.annotation.RetentionPolicy;import java.lang.annotation.Target;@Retention(RetentionPolicy.RUNTIME)@Target(ElementType.TYPE)public @interface Table { String value();}

Column注解,作用域在字段名@Target(ElementType.FIELD)生命周期为@Retention(RetentionPolicy.RUNTIME)

package com.susu;import java.lang.annotation.ElementType;import java.lang.annotation.Retention;import java.lang.annotation.RetentionPolicy;import java.lang.annotation.Target;@Retention(RetentionPolicy.RUNTIME)@Target(ElementType.FIELD)public @interface Column { String value();}

User实体类。

package com.susu;@Table("user")public class User { @Column("id") private int id; @Column("username") private String username; @Column("nickname") private String nickname; @Column("age") private int age; @Column("gender") private String gender; @Column("city") private String city; @Column("email") private String email; @Column("phoneNumber") private String phoneNumber; public User() { super(); // TODO Auto-generated constructor stub } public int getId() { return id; } public void setId(int id) { this.id = id; } public String getUsername() { return username; } public void setUsername(String username) { this.username = username; } public String getNickname() { return nickname; } public void setNickname(String nickname) { this.nickname = nickname; } public int getAge() { return age; } public void setAge(int age) { this.age = age; } public String getGender() { return gender; } public void setGender(String gender) { this.gender = gender; } public String getCity() { return city; } public void setCity(String city) { this.city = city; } public String getEmail() { return email; } public void setEmail(String email) { this.email = email; } public String getPhoneNumber() { return phoneNumber; } public void setPhoneNumber(String phoneNumber) { this.phoneNumber = phoneNumber; }}

下面是测试类

package com.susu;import java.lang.reflect.Field;import java.lang.reflect.Method;public class Test { public static void main(String[] args) { User user1=new User(); user1.setNickname("小明"); user1.setAge(10); User user2=new User(); user2.setUsername("张三"); User user3=new User(); user3.setEmail("1142819049@qq.com"); user3.setCity("北京"); query(user1); query(user2); query(user3); } @SuppressWarnings({ "rawtypes", "unchecked" }) private static void query(Object obj) { StringBuilder sb=new StringBuilder(); Class c=obj.getClass(); //如果类不包含@Table注解 结束 if(!c.isAnnotationPresent(Table.class)){ return ; } //获得表名 Table table= (Table) c.getAnnotation(Table.class); sb.append("select * from "+table.value()+" where 1 = 1"); Field fields[]=c.getDeclaredFields(); for (Field field : fields) { //如果该字段不包含@Column注解 遍历下一个 if(!field.isAnnotationPresent(Column.class)){ continue; } //获得字段名 Column column=field.getAnnotation(Column.class); String columnName=column.value(); String fieldName=field.getName(); //获取该字段的get方法 String methodName="get"+fieldName.substring(0, 1).toUpperCase()+fieldName.substring(1); try { Method method=c.getDeclaredMethod(methodName); Object o =method.invoke(obj); if(o==null||(o instanceof Integer&&(Integer)o==0)){ continue; } //拼装sql if(o instanceof String){ sb.append(" and "+columnName+" = '"+o+"'"); }else if(o instanceof Integer){ sb.append(" and "+columnName+" = "+o); } } catch (Exception e) { e.printStackTrace(); } } System.out.println(sb.toString()); }}

运行结果:

我们可以使用@Table和@Column这两个注解 对新的表 新的字段进行拼装sql查询语句

比如,新表

package com.susu;@Table("Department")public class Department { @Column("id") private int id; @Column("leader") private String leader; @Column("city") private String name; @Column("city") private String city; public Department() { super(); // TODO Auto-generated constructor stub } public int getId() { return id; } public void setId(int id) { this.id = id; } public String getLeader() { return leader; } public void setLeader(String leader) { this.leader = leader; } public String getName() { return name; } public void setName(String name) { this.name = name; } public String getCity() { return city; } public void setCity(String city) { this.city = city; } }

在测试类里面继续调用

Department dep1=new Department(); dep1.setId(5); dep1.setLeader("张三"); dep1.setCity("上海"); Department dep2=new Department(); dep2.setCity("成都"); query(dep1); query(dep2);

运行结果:

版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。

上一篇:JAVA进阶案例 TCP编程之网络聊天工具(客户端)
下一篇:java输入输出流复制文件所用时间对比
相关文章

 发表评论

暂时没有评论,来抢沙发吧~