框架=注解+反射+设计模式 & 注解

框架通过注解来标记和扩展代码,使用反射机制在运行时动态处理这些标记,并结合设计模式来组织代码和提供最佳实践。

注解(Annotation):注解是Java提供的一种元数据标记机制,用于为代码添加元数据信息。框架通过注解来定义和标记代码中的特定部分,以便在运行时或编译时进行解析和处理。注解可以用来标记类、方法、变量等,提供了一种与代码分离的方式来扩展和定制框架的功能。
反射(Reflection):反射是Java中一种能够在运行时对类、接口、字段和方法进行查询和操作的能力。框架通过反射机制,可以在运行时动态地加载类、创建对象、调用方法和获取字段值等。这使得框架具有更灵活和动态的特性,可以根据注解或其他元数据信息在运行时动态地处理代码。
设计模式(Design Pattern):设计模式是解决常见问题的最佳实践。框架中采用各种设计模式,如工厂模式、单例模式、观察者模式等,可以帮助开发者更加高效地构建软件应用程序。设计模式提供了一种组织代码和模块化的方式,使得代码更加可维护、可扩展和可重用。

这三个部分共同构成了框架的核心,使得框架能够提供一种结构化和可扩展的开发方式,简化开发过程并提高应用程序的质量。

什么是注解

注解其实就是代码里的特殊标记,这些标记可以在编译、类加载、运行时被读取,并执行相应的处理。通过使用注解,可以在不改变原有逻辑的情况下,在源文件中嵌入一些补充信息。代码分析工具、开发工具和部署工具可以通过这些补充信息进行验证或者进行部署。使用注解时要在其前面增加@符号,并把该注解当成一个修饰符使用,可修饰包、类、构造器、方法、成员变量、参数、局部变量,这些信息被保存在注解的 "name=value"键值对中。

作用:

  • 元数据标记:用于标记代码中的特定元素,以便在编译时或运行时进行处理。
  • 配置信息:用于提供配置信息,例如框架的配置参数、数据库连接信息等。
  • 编译时检查:通过使用编译时注解,可以在编译阶段对代码进行额外的检查或处理。
  • 运行时处理:运行时注解可以在运行时被应用程序读取和处理,例如用于生成文档、生成代码、生成测试用例等。

Spring框架

1)类级别的注解:

用于声明一个类为特定的组件类型,以便于Spring容器对其进行管理和依赖注入。

@Component:

将一个类声明为Spring组件,没有明确的角色。当一个类被标注为@Component时,Spring会自动检测该类,并将其注册为一个Bean,这样就可以在应用程序中使用该组件。

@Controller:

该注解用于标注控制类,通常用于Web应用程序的开发。被@Controller标注的类通常用于处理HTTP请求并返回相应的响应,可以与视图层进行交互。

@Service:

标注业务逻辑层组件,通常用于标注服务类。被@Service标注的类通常包含了一些业务逻辑,并且可以与数据访问层进行交互。

@Repository:

标注数据访问层组件,通常用于标注数据访问类。被@Repository标注的类用于与数据库进行交互,包括数据的增删改查等操作。

这些注解只是声明了一个组件或类,要使其生效还需要将其注册到Spring容器中。可以通过在配置文件中显式地注册Bean,或者使用@ComponentScan等注解来自动扫描并注册Bean。

2)类内部的注解:

主要用于字段、构造器参数和方法参数上,用于注入依赖和配置属性。

@Autowired:

自动注入依赖项。它可以自动地将相关的bean注入到被标注的字段、构造器或方法中,提供了灵活的依赖注入方式。

@Resource:

与@Autowired类似,也可以用于注入依赖项。不同的是,@Resource可以根据名称进行注入,@Autowired则根据类型进行注入。

@Value:

给简单类型的属性赋值,可以指定属性值。它可以用于字段、构造器参数或方法参数上,用于注入指定的值。

@Required:

标记一个setter方法为必需的,如果在Spring容器中没有为该字段注入值,则会抛出异常。

3)切面相关的注解:

在面向切面编程(AOP)中,Spring框架提供了几个常用的注解,用于定义通知(advice)和切点(pointcut)。

如@Aspect、@Before、@After、@Around等,它们用于声明一个切面,并定义通知,可直接将拦截规则(切点)作为参数。通过在方法调用之前、之后等特定时刻执行特定的代码逻辑,实现对方法调用的增强和拦截。

这些注解可以帮助开发人员更好地组织和管理业务逻辑和横切关注点(cross-cutting concerns),例如日志记录、事务管理、安全验证等。

MyBatis框架

在MyBatis框架中,注解被广泛用于简化XML配置,实现映射、查询、更新、删除等操作。

@Insert、@Delete、@Update、@Select:

实现对数据库表的增删改查操作,需要指定SQL语句和参数类型。
@Results 和 @Result:

实现结果集的封装。可以将查询结果映射成Java对象或Map类型,便于在应用程序中使用。
@Param:

传递多个参数给SQL语句。当需要传递多个参数给查询、更新或删除操作时,可以使用该注解指定参数名称。

这些注解可以直接写在Mapper接口的方法上,MyBatis会自动解析并执行对应的SQL语句。与XML配置相比,注解方式更加简洁,易于阅读和维护。

你可能感兴趣的:(java,开发语言)