升级你的Logger(注解+动态代理)

升级你的Logger(注解+动态代理),第1张

基于Android的Log进行了一层简单的封装,以一个demo的形式呈现。

我们在自定义Log的时候,应该考虑到的几点:

描述: 利用注解描述一个类型的日志,利用动态代理生成一种日志类型。

直接看demo,简单粗暴:

日志等级枚举:

普通的日志类,可以实例化之后使用:

Config注解,描述一种类型的日志:开关、等级、名称(log前缀):

日志接口,利用Config注解添加一种日志类型

动态代理,Logger的代理类,可以生成和管理所有Logger:

对上面的那些类封装一层,对外提供日志的能力,DSLog:

demo日志器就做好了,在上面扩展功能也是非常容易的~

欢迎拿去食用~

动态代理中的切点是指需要被代理的方法或接口。切点可以通过定义一个接口或者类来实现。在接口或类中定义需要被代理的方法,然后在代理类中实现该接口或继承该类,即可对这些方法进行代理。切点还可以通过注解来实现,即在需要被代理的方法上添加注解,然后在代理类中根据注解来判断需要代理的方法。另外,切点还可以通过正则表达式来实现,即根据方法名或方法参数的正则表达式来匹配需要被代理的方法。

看似加个注解就ok了,但是实际可能就会用错了,有时候不起作用,容易被忽略。

1、@Transactional 注解只能应用到 public访问权限的方法上 。 如果你在 protected、private 或者 package-visible 的方法上使用 @Transactional 注解,它也不会报错, 但是这个被注解的方法将不起事务作用。

标注@Transactional的方法如果修饰符不是public,那么就默认方法的@Transactional信息为空,那么将不会对bean进行代理对象创建或者不会对方法进行代理调用

2、@Transactional 注解的使用,必须在配置文件中配置事务相关信息。(springboot不用配置)

3、在测试类中,

直接调用A,有事务会回滚

调用B,不会回滚。

解决方案,A和B放在不同的service里面。

因为spring事务是基于类和接口的,所以只能在类里面调用另一个类里面的事务,同一个类里面调用自己类的事务方法是无效的。

事务管理是基于动态代理对象的代理逻辑实现的,那么如果在类内部调用类内部的事务方法,这个调用事务方法的过程并不是通过代理对象来调用的,而是直接通过this对象来调用方法,绕过的代理对象,肯定就是没有代理逻辑了。

@Service

public class TestService{

@transaction

public void A(){

dao.insert();

int a = 1/0

}

public void B(){

A()

}

}

登录后复制

4、自己trycatch了一下。

5、

B是一个事务,A新起一个事务,事实上A、B在一个事物里面。

@Service

public class TestService{

@transaction(propgation = propgation.request_new)

public void A(){

dao.insert();

int a = 1/0

}

@transaction

public void B(){

A()

}

}


欢迎分享,转载请注明来源:内存溢出

原文地址:https://www.54852.com/bake/11728142.html

(0)
打赏 微信扫一扫微信扫一扫 支付宝扫一扫支付宝扫一扫
上一篇 2023-05-18
下一篇2023-05-18

发表评论

登录后才能评论

评论列表(0条)

    保存