今晚读了think in java 的章节,感觉很不错,我就敲了下来,贴上代码给以后一个回顾:
建议提前读一下think in java 注解 。
说明创建注解我在第一个注解说明下,以后的注解不在说明。‘
DBTable 注解:
/** * Project Name:myannotation * File Name:DBTable.java * Package Name:com.iflytek.db * Date:2016-8-28下午08:20:54 * Copyright (c) 2016, syzhao@iflytek.com All Rights Reserved. * */ package com.iflytek.db; import java.lang.annotation.ElementType; import java.lang.annotation.Retention; import java.lang.annotation.RetentionPolicy; import java.lang.annotation.Target; /** @Target: @Target说明了Annotation所修饰的对象范围:Annotation可被用于 packages、types(类、接口、枚举、Annotation类型)、类型成员(方法、构造方法、成员变量、枚举值)、方法参数和本地变量(如循环变量、catch参数)。在Annotation类型的声明中使用了target可更加明晰其修饰的目标。 作用:用于描述注解的使用范围(即:被描述的注解可以用在什么地方) 取值(ElementType)有: 1.CONSTRUCTOR:用于描述构造器 2.FIELD:用于描述域 3.LOCAL_VARIABLE:用于描述局部变量 4.METHOD:用于描述方法 5.PACKAGE:用于描述包 6.PARAMETER:用于描述参数 7.TYPE:用于描述类、接口(包括注解类型) 或enum声明 @Retention: @Retention定义了该Annotation被保留的时间长短:某些Annotation仅出现在源代码中,而被编译器丢弃;而另一些却被编译在class文件中;编译在class文件中的Annotation可能会被虚拟机忽略,而另一些在class被装载时将被读取(请注意并不影响class的执行,因为Annotation与class在使用上是被分离的)。使用这个meta-Annotation可以对 Annotation的“生命周期”限制。 作用:表示需要在什么级别保存该注释信息,用于描述注解的生命周期(即:被描述的注解在什么范围内有效) 取值(RetentionPoicy)有: 1.SOURCE:在源文件中有效(即源文件保留) 2.CLASS:在class文件中有效(即class保留) 3.RUNTIME:在运行时有效(即运行时保留) Retention meta-annotation类型有唯一的value作为成员,它的取值来自java.lang.annotation.RetentionPolicy的枚举类型值 */ @Target(ElementType.TYPE) @Retention(RetentionPolicy.RUNTIME) public @interface DBTable { public String name() default ""; }
Constraints 约束注解:
/** * Project Name:myannotation * File Name:Constraints.java * Package Name:com.iflytek.db * Date:2016-8-28下午08:27:08 * Copyright (c) 2016, syzhao@iflytek.com All Rights Reserved. * */ package com.iflytek.db; import java.lang.annotation.ElementType; import java.lang.annotation.Retention; import java.lang.annotation.RetentionPolicy; import java.lang.annotation.Target; @Target(ElementType.FIELD) @Retention(RetentionPolicy.RUNTIME) public @interface Constraints { boolean primaryKey() default false; boolean allowNull() default true; boolean unique() default false; }
SQLInteger int注解:
/** * Project Name:myannotation * File Name:SQLInteger.java * Package Name:com.iflytek.db * Date:2016-8-29下午10:24:11 * Copyright (c) 2016, syzhao@iflytek.com All Rights Reserved. * */ package com.iflytek.db; import java.lang.annotation.ElementType; import java.lang.annotation.Retention; import java.lang.annotation.RetentionPolicy; import java.lang.annotation.Target; @Target(ElementType.FIELD) @Retention(RetentionPolicy.RUNTIME) public @interface SQLInteger { String name() default ""; Constraints constraints() default @Constraints; }
SQLString 字符注解:
/** * Project Name:myannotation * File Name:SQLString.java * Package Name:com.iflytek.db * Date:2016-8-29下午10:28:04 * Copyright (c) 2016, syzhao@iflytek.com All Rights Reserved. * */ package com.iflytek.db; import java.lang.annotation.ElementType; import java.lang.annotation.Retention; import java.lang.annotation.RetentionPolicy; import java.lang.annotation.Target; @Target(ElementType.FIELD) @Retention(RetentionPolicy.RUNTIME) public @interface SQLString { int value() default 0; String name() default ""; Constraints constraints() default @Constraints; }
创建表的处理器:
/** * Project Name:myannotation * File Name:TableCreator.java * Package Name:com.iflytek.table * Date:2016-8-29下午10:57:52 * Copyright (c) 2016, syzhao@iflytek.com All Rights Reserved. * */ package com.iflytek.table; import java.lang.annotation.Annotation; import java.lang.reflect.Field; import java.util.ArrayList; import java.util.List; import com.iflytek.db.Constraints; import com.iflytek.db.DBTable; import com.iflytek.db.SQLInteger; import com.iflytek.db.SQLString; public class TableCreator { public static void main(String[] args) { createTable(Member.class); } //创建表SQL语句 private static void createTable(Class<?> cl) { //获取DBTable注解 DBTable dbTable = cl.getAnnotation(DBTable.class); //判断DBTable注解是否存在 if (dbTable == null) { System.out.println("没有找到关于DBTable"); return; } //如果@DBTable注解存在获取表明 String tableName = dbTable.name(); //判断表名是否存在 if (tableName.length() < 1) { //不存在,说明默认就是类名,通过 cl.getSimpleName()获取类名并且大写 tableName = cl.getSimpleName().toUpperCase(); } //定义获取column的容器 List<String> columnDefs = new ArrayList<String>(); //循环属性字段 //说明:getDeclaredFields()获得某个类的所有申明的字段,即包括public、private和proteced,但是不包括父类的申明字段。 //getFields()获得某个类的所有的公共(public)的字段,包括父类。 for (Field field : cl.getDeclaredFields()) { //定义表字段名称变量 String columnName = null; //获取字段上的注解(现在字段允许多个注解,因此返回的是数组) Annotation[] anns = field.getDeclaredAnnotations(); //判断属性是否存在注解 if (anns.length < 1) continue; //判断是否是我们定义的数据类型 if (anns[0] instanceof SQLInteger) { //获取SQLInteger 注解 SQLInteger sInt = (SQLInteger)anns[0]; //判断是否注解的name是否有值 if (sInt.name().length() < 1) { //如果没有值,说明是类的属性字段,获取属性并转换大写 columnName = field.getName().toUpperCase(); } else { //如果有值,获取设置的name值 columnName = sInt.name(); } //放到属性的容器内 columnDefs.add(columnName + " INT " + getConstraints(sInt.constraints())); } //同上SQLInteger,这里不写注释了 if (anns[0] instanceof SQLString) { SQLString sString = (SQLString)anns[0]; if (sString.name().length() < 1) { columnName = field.getName().toUpperCase(); } else { columnName = sString.name(); } columnDefs.add(columnName + " VARCHAR(" + sString.value() + ")" + getConstraints(sString.constraints())); } //定义生成创建表的SQL语句 StringBuilder createCommand = new StringBuilder("CREATE TABLE " + tableName + "("); //循环上面属性容器, for (String columnDef : columnDefs) { //把属性添加到sql语句中 createCommand.append("\n " + columnDef + ","); //去掉最后一个逗号 String tableCreate = createCommand.substring(0, createCommand.length() - 1) + ");"; //打印 System.out.println("Table creation SQL for " + cl.getName() + " is :\n" + tableCreate); } } } private static String getConstraints(Constraints con) { String constraints = ""; //判断是否为null if (!con.allowNull()) { constraints += " NOT NULL "; } //判断是否是主键 if (con.primaryKey()) { constraints += " PRIMARY KEY "; } //是否唯一 if (con.unique()) { constraints += " UNIQUE "; } return constraints; } }
以上代码拷贝出来,就可以运行了!
上面虽然是简单的创建表语句,但我们可以蔓延到hibernate的domain类里的注解,各种CURD ,何尝不是这样处理的呢,只是hibernate有很多东西,但是万变不离其宗,以后有机会研究一下hibernate 。
收获:
读了以后,对于注解知道为什么要这么用了,其实顾名思义就是一个注解,只是有一个处理器来处理这个注解,这对我以后用到注解方面应该有帮助的,
时间不早了,就写到这里!
结果:
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
免责声明:本站资源来自互联网收集,仅供用于学习和交流,请遵循相关法律法规,本站一切资源不代表本站立场,如有侵权、后门、不妥请联系本站删除!
《魔兽世界》大逃杀!60人新游玩模式《强袭风暴》3月21日上线
暴雪近日发布了《魔兽世界》10.2.6 更新内容,新游玩模式《强袭风暴》即将于3月21 日在亚服上线,届时玩家将前往阿拉希高地展开一场 60 人大逃杀对战。
艾泽拉斯的冒险者已经征服了艾泽拉斯的大地及遥远的彼岸。他们在对抗世界上最致命的敌人时展现出过人的手腕,并且成功阻止终结宇宙等级的威胁。当他们在为即将于《魔兽世界》资料片《地心之战》中来袭的萨拉塔斯势力做战斗准备时,他们还需要在熟悉的阿拉希高地面对一个全新的敌人──那就是彼此。在《巨龙崛起》10.2.6 更新的《强袭风暴》中,玩家将会进入一个全新的海盗主题大逃杀式限时活动,其中包含极高的风险和史诗级的奖励。
《强袭风暴》不是普通的战场,作为一个独立于主游戏之外的活动,玩家可以用大逃杀的风格来体验《魔兽世界》,不分职业、不分装备(除了你在赛局中捡到的),光是技巧和战略的强弱之分就能决定出谁才是能坚持到最后的赢家。本次活动将会开放单人和双人模式,玩家在加入海盗主题的预赛大厅区域前,可以从强袭风暴角色画面新增好友。游玩游戏将可以累计名望轨迹,《巨龙崛起》和《魔兽世界:巫妖王之怒 经典版》的玩家都可以获得奖励。
更新日志
- 小骆驼-《草原狼2(蓝光CD)》[原抓WAV+CUE]
- 群星《欢迎来到我身边 电影原声专辑》[320K/MP3][105.02MB]
- 群星《欢迎来到我身边 电影原声专辑》[FLAC/分轨][480.9MB]
- 雷婷《梦里蓝天HQⅡ》 2023头版限量编号低速原抓[WAV+CUE][463M]
- 群星《2024好听新歌42》AI调整音效【WAV分轨】
- 王思雨-《思念陪着鸿雁飞》WAV
- 王思雨《喜马拉雅HQ》头版限量编号[WAV+CUE]
- 李健《无时无刻》[WAV+CUE][590M]
- 陈奕迅《酝酿》[WAV分轨][502M]
- 卓依婷《化蝶》2CD[WAV+CUE][1.1G]
- 群星《吉他王(黑胶CD)》[WAV+CUE]
- 齐秦《穿乐(穿越)》[WAV+CUE]
- 发烧珍品《数位CD音响测试-动向效果(九)》【WAV+CUE】
- 邝美云《邝美云精装歌集》[DSF][1.6G]
- 吕方《爱一回伤一回》[WAV+CUE][454M]