Java如何获得调用当前方法的方法名

Thread.currentThread().getStackTrace()[1]是你当前方法执行堆栈 
Thread.currentThread().getStackTrace()[2]就是上一级的方法堆栈 以此类推
StackTraceElement[] temp=Thread.currentThread().getStackTrace();
StackTraceElement a=(StackTraceElement)temp[2];
this.logger.info("----from--"+a.getMethodName()+"--method----------to use-refreshcart--------");

a.getMethodName() 这就是调用当前方法的方法名称

 

这里面 :通过获取堆栈可以不仅可以获取调用当前方法的方法,还可以获取方法的具体位置行数、调用方法的方法类型、  类名等;获取执行堆栈的方法这里是写在方法中的第一行的,如果这个方法前面还有很多其他方法,会导致方法堆栈层级越来越多,但不会影响当前方法的上一级的堆栈信息位置(一直在数组下标为2的位置)。

  • 7
    点赞
  • 17
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值