springIOC和AOP的理解

Spring的IOC理解

1.IOC 控制反转,是指创建对象的控制权转移,以前创建对象的主动权和时机是由自己把控的,而现在这种权力转移到spring容器中,并由容器根据配置文件去创建实例和管理各个实例之间的依赖关系,对象与对象之间松散耦合,也利于功能的复用。DI依赖注入,和控制反转是同一个概念的不同角度的描述,即应用程序在运行时依赖IOC容器来动态注入对象需要的外部资源

2.最直观的表达就是,IOC让对象的创建不用去new了,可以由spring自动生产,使用java的反射机制,根据配置文件在运行时动态的去创建对象以及管理对象,并调用对象的方法

3.spring的IOC有三种注入:setter方法注入,构造器注入,接口注入

Spring的AOP理解

OOP面向对象,允许开发者定义纵向关系,但并适用于定义横向的关系,导致了大量代码的重复,而不利于各个模块的重用。

AOP,一般称为面向切面,作为面向对象的一种补充,用于将那些与业务无关,但却对多个对象产生影响的公共行为和逻辑,抽取并封装为一个可重用的模块,这个模块被命名为“切面(asoect)”,减少系统中的重复代码,降低了模块间的耦合度,同时提高系统的可维护性。可用于权限认证、日志、事务处理

AOP实现的关键在于代理模式,AOP代理主要分为静态代理和动态代理。静态代理的代表为Aspectj(a四被t J);动态代理则以spring AOP为代表

1.Aspectj是静态代理的增加,所谓静态代理,就是AOP框架会在编译阶段生成AOP代理类,因此也称为编译时增强,他会在编译阶段将Aspectj(切面)织入到java字节码中,运行的时候就是增强之后的AOP对象

2.SpringAOP使用的动态代理,所谓的动态代理就是说AOP框架不会去修改字节码,而是每次运动时在内存中临时为方法生成一个AOP对象,这个AOP对象包含了目标对象的全部方法,并且在特定的切点做了增强处理,并回调原对象的方法。

SpringAOP中的动态代理主要有俩种方式,JDK动态代理和CGLIB动态代理:

1.JDK动态代理只提供接口的代理,不支持类的代理。

2.静态代理与动态代理区别在于生成AOP代理对象的时机不同,相对来说AspectJ的静态代理方式具有更好的性能,但是AspectJ需要特定的编译器进行处理,而Spring AOP则无需特定的编译器处理。

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
Spring IOC (Inversion of Control) 是一种设计模式,用于管理和组织应用程序中的对象之间的依赖关系。它通过将控制权从应用程序代码中转移给一个容器,从而实现了松耦合和可维护性。在Spring框架中,IOC容器负责创建、组装和管理对象的生命周期。 举个例子来说明,假设我们有一个应用程序,其中包含了 User 和 Order 两个类。在传统的编程方式中,我们需要手动创建这些对象,并在需要的地方进行依赖注入。但在Spring IOC中,我们只需要在配置文件中定义好这些对象,并让容器管理它们的创建和销毁。当我们需要使用这些对象时,只需要从容器中获取即可。 例如,我们可以使用 `<bean>` 标签在配置文件中定义一个 User 对象: ``` <bean id="user" class="com.example.User"> <property name="name" value="John" /> <property name="age" value="25" /> </bean> ``` 然后,在代码中可以通过获取 `user` 对象的实例: ``` User user = (User) applicationContext.getBean("user"); ``` 这样,我们就实现了对象的创建和依赖注入,而不需要手动管理对象的生命周期。 接下来是AOP(Aspect-Oriented Programming),它是一种编程范式,用于解决在面向对象编程中横切关注点的问题。AOP通过将横切关注点(如日志记录、事务管理等)与主要业务逻辑分离,使得代码更加模块化和可维护。 举个例子来说明,假设我们有一个应用程序,其中包含了多个服务类,每个服务类都需要进行日志记录。在传统的编程方式中,我们需要在每个服务类的方法中添加日志记录的代码。但是在AOP中,我们可以通过定义一个切面(Aspect)来实现日志记录功能,并将其应用到需要的方法上。 例如,我们可以使用 Spring AOP 来实现日志记录功能。首先,我们需要引入`spring-boot-starter-aop`依赖。然后,在切面类中定义日志记录的逻辑: ``` @Aspect @Component public class LoggingAspect { @Before("execution(* com.example.service.*.*(..))") public void beforeMethod(JoinPoint joinPoint) { // 日志记录逻辑 System.out.println("Before method: " + joinPoint.getSignature().getName()); } } ``` 在上述例子中,我们使用 `@Before` 注解来定义在方法执行之前执行的逻辑。通过 `JoinPoint` 参数,我们可以获取到方法的签名信息并进行相应的处理。 最后,在需要应用日志记录的方法上添加相应的注解即可: ``` @Service public class UserService { @LogBeforeMethod public void addUser(User user) { // 添加用户逻辑 } } ``` 在上述例子中,我们使用 `@LogBeforeMethod` 注解来说明在该方法执行之前需要应用日志记录的切面。 通过以上的例子,我们可以看到Spring IOCAOP的作用和应用。IOC通过容器管理对象的创建和依赖注入,使得代码更加模块化和可维护;而AOP通过切面的方式实现横切关注点的功能,提高了代码的复用性和可维护性。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* [SpringIOCAOP理解之深入浅出(建议收藏)](https://blog.csdn.net/weixin_45105261/article/details/112004029)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] - *2* *3* [SpringBoot 切面AOP实现权限校验:实例演示与注解全解](https://blog.csdn.net/chali1314/article/details/115317063)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Qinꦿ.๓

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值