工作笔记-注解 Annotation

本文深入解析Java注解的原理与应用,包括注解的使用场景、预定义注解、自定义注解及元注解等内容,揭示注解如何增强代码功能并简化开发流程。

注解是java.lang.annotation包提供的功能(我一度以为是Spring的特性?),Spring利用注解做了非常多的事情,注解也让很多集成工作变得非常轻松和简单,同时太过完美的封装也会带来弊端,那就是代码藏得太深了。。

注解本身做的事情非常少,大部分是提供识别的功能。

注解的使用场景

注解一般在声明时使用,比如类、字段、方法和其他程序元素的声明,将注解写在声明时,通常是单独一行写在声明的前面,比如:

	@Description(name="name",descrip ="descript")
	public String className;

Java8以后,注解可以添加在任意的类型之前,比如

1. 创建对象实例时

new @Interned MyObject();

2. 类型转换时

myString = (@NonNull String) str;

3. 接口实现

 class UnmodifiableList<T> implements
        @Readonly List<@Readonly T> { ... }

4. 抛异常声明

void monitorTemperature() throws
        @Critical TemperatureException { ... }

预定义的注解

Java SE API中预定义了一组注解类型。有些注解类型由Java编译器使用,有些则应用于其他注解。

@Deprecated 注解表示标记的元素已被弃用,不应该再使用。每当程序使用带有@Deprecated注释的方法、类或字段时,编译器都会生成警告。当一个元素被弃用时,还应该使用Javadoc @deprecated标记记录它,如下面的示例所示。在Javadoc注解和注释中使用@并非巧合:它们在概念上是相关的。另外,注意Javadoc标记以小写d开头,注释以大写D开头。

// Javadoc comment follows
    /**
     * @deprecated
     * explanation of why it was deprecated
     */
    @Deprecated
    static void deprecatedMethod() { }
}

@Override 注释通知编译器,该元素意味着重写父类中声明的元素。

// mark method as a superclass method
   // that has been overridden
   @Override 
   int overriddenMethod() { }

@SuppressWarnings 注解告诉编译器忽略它将会产生的特定警告。在下面的例子中,使用了一个已弃用的方法,编译器通常会生成一个警告。但是,在这种情况下,注解会导致警告被忽略。

  // use a deprecated method and tell 
   // compiler not to generate a warning
   @SuppressWarnings("deprecation")
    void useDeprecatedMethod() {
        // deprecation warning
        // - suppressed
        objectOne.deprecatedMethod();
    }

每个编译器警告都属于一个类别。Java语言规范列出了两类:deprecated和unchecked。当与泛型出现之前编写的遗留代码交互时,可能会出现unchecked的警告。要忽略多个类别的警告,请使用以下语法:

@SuppressWarnings({“unchecked”、“deprecated”})

@SafeVarargs 当应用于方法或构造函数时,@SafeVarargs 注解断言代码不会对其varargs参数执行潜在的不安全操作。

@FunctionalInterface Java SE 8中引入的@FunctionalInterface 表示被注解的类型声明为功能接口(functional Interface)。

注解的注解

应用于其他注解的注解称为元注解(meta-annotations)。在java.lang.annotation中定义了几种元注解类型。

1. @Retention

@Retention注解指定标记的注解是如何保存的:

RetentionPolicy.SOURCE——标记的注解只保留在源代码级别,并被编译器忽略。

RetentionPolicy.CLASS——标记的注解在编译时由编译器保留,但是被Java虚拟机(JVM)忽略。

RetentionPolicy.RUNTIME——标记的注释由JVM保留,以便运行时环境可以使用它。

2.@Documentation

@Documentation注解指出,无论何时使用指定的注解,这些元素都应该使用Javadoc工具进行文档化。(默认情况下,Javadoc中不包含注解。)

3.@Target

使用@Target注解来限制被标记的注解可以应用于哪种Java元素。目标注解指定以下元素类型之一作为其值:

  • ElementType.ANNOTATION_TYPE 注解

  • ElementType.CONSTRUCTOR 构造函数

  • ElementType.FIELD 属性

  • ElementType.LOCAL_VARIABLE 局部变量

  • ElementType.METHOD 方法

  • ElementType.PACKAGE 包声明

  • ElementType.PARAMETER 参数

  • ElementType.TYPE 类声明

4. @inheritance

@inheritance注解表示可以从父类继承注解类型(默认情况下并非如此。),这个注解只适用于类声明。

5. Repeatable

Java SE 8中引入的@Repeatable注解表明,标记的注解可以不止一次应用于相同的声明或类型使用。

使用注解

举例,我自定义了一个注解

@Documented
@Retention(RetentionPolicy.RUNTIME)
@Target(ElementType.FIELD)
public @interface Description {
	
	String name() default "";

	String descrip() default "";
}

这个注解被应用于ElementType.FIELD也就是类的属性上,同时RetentionPolicy.RUNTIME表明其可以被JVM识别。

示例注解有两个可以赋值的属性name()和descript();

下面声明一个类,使用我们自定义的注解来标注。

public class AnnotationDemo {

	@Description(name="fieldName",descrip ="descript")
	public String className;
	
	public String getClassName(){
		return this.className;
	}
	
	public void setClassName(String className){
		this.className = className;
	}
	
}

在使用中获取注解的值:

		AnnotationDemo ad = new AnnotationDemo();
		Description an = null;;
		try {
			an = ad.getClass().getField("className").getAnnotation(Description.class);
		} catch (NoSuchFieldException e) {
			// TODO Auto-generated catch block
			e.printStackTrace();
		} catch (SecurityException e) {
			// TODO Auto-generated catch block
			e.printStackTrace();
		}
		if(null!=an){
			System.out.println("getAnnotation:"+an.name()+an.descrip());
		}

输出结果:

getAnnotation:fieldNamedescript

以上是java注解的基础内容。就是这么一个小小的功能,可以支撑起很多强大的框架。

内容概要:本文设计了一种基于PLC的全自动洗衣机控制系统内容概要:本文设计了一种,采用三菱FX基于PLC的全自动洗衣机控制系统,采用3U-32MT型PLC作为三菱FX3U核心控制器,替代传统继-32MT电器控制方式,提升了型PLC作为系统的稳定性与自动化核心控制器,替代水平。系统具备传统继电器控制方式高/低水,实现洗衣机工作位选择、柔和过程的自动化控制/标准洗衣模式切换。系统具备高、暂停加衣、低水位选择、手动脱水及和柔和、标准两种蜂鸣提示等功能洗衣模式,支持,通过GX Works2软件编写梯形图程序,实现进洗衣过程中暂停添加水、洗涤、排水衣物,并增加了手动脱水功能和、脱水等工序蜂鸣器提示的自动循环控制功能,提升了使用的,并引入MCGS组便捷性与灵活性态软件实现人机交互界面监控。控制系统通过GX。硬件设计包括 Works2软件进行主电路、PLC接梯形图编程线与关键元,完成了启动、进水器件选型,软件、正反转洗涤部分完成I/O分配、排水、脱、逻辑流程规划水等工序的逻辑及各功能模块梯设计,并实现了大形图编程。循环与小循环的嵌; 适合人群:自动化套控制流程。此外、电气工程及相关,还利用MCGS组态软件构建专业本科学生,具备PL了人机交互C基础知识和梯界面,实现对洗衣机形图编程能力的运行状态的监控与操作。整体设计涵盖了初级工程技术人员。硬件选型、; 使用场景及目标:I/O分配、电路接线、程序逻辑设计及组①掌握PLC在态监控等多个方面家电自动化控制中的应用方法;②学习,体现了PLC在工业自动化控制中的高效全自动洗衣机控制系统的性与可靠性。;软硬件设计流程 适合人群:电气;③实践工程、自动化及相关MCGS组态软件与PLC的专业的本科生、初级通信与联调工程技术人员以及从事;④完成PLC控制系统开发毕业设计或工业的学习者;具备控制类项目开发参考一定PLC基础知识。; 阅读和梯形图建议:建议结合三菱编程能力的人员GX Works2仿真更为适宜。; 使用场景及目标:①应用于环境与MCGS组态平台进行程序高校毕业设计或调试与运行验证课程项目,帮助学生掌握PLC控制系统的设计,重点关注I/O分配逻辑、梯形图与实现方法;②为工业自动化领域互锁机制及循环控制结构的设计中类似家电控制系统的开发提供参考方案;③思路,深入理解PL通过实际案例理解C在实际工程项目PLC在电机中的应用全过程。控制、时间循环、互锁保护、手动干预等方面的应用逻辑。; 阅读建议:建议结合三菱GX Works2编程软件和MCGS组态软件同步实践,重点理解梯形图程序中各环节的时序逻辑与互锁机制,关注I/O分配与硬件接线的对应关系,并尝试在仿真环境中调试程序以加深对全自动洗衣机控制流程的理解。
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值