
基于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()
}
}
欢迎分享,转载请注明来源:内存溢出
微信扫一扫
支付宝扫一扫
评论列表(0条)