首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >专栏 >Arthas jad(字节码文件反编译成源代码 )

Arthas jad(字节码文件反编译成源代码 )

原创
作者头像
刘大猫
发布2025-05-08 20:14:51
发布2025-05-08 20:14:51
2230
举报
文章被收录于专栏:JAVA相关JAVA相关

@toc

二、命令列表

2.2 class/classloader相关命令

2.2.1 jad(字节码文件反编译成源代码 )

提示:

jad 命令将 JVM 中实际运行的 class 的 byte code 反编译成 java 代码,便于你理解业务逻辑

参数说明:

参数名称

参数说明

class-pattern

类名表达式匹配

[c:]

类所属 ClassLoader 的 hashcode

[classLoaderClass:]

指定执行表达式的 ClassLoader 的 class name

E

开启正则表达式匹配,默认为通配符匹配

举例1:反编译指定的函数 :jad com.hero.lte.ems.sysmanager.cache.SMTaskCache executeTask

基本用法: jad 全路径类名 方法名

代码语言:java
复制
[arthas@24056]$ jad com.hero.lte.ems.sysmanager.cache.SMTaskCache executeTask

ClassLoader:                                                                                                                                                                                                                            
+-sun.misc.Launcher$AppClassLoader@18b4aac2                                                                                                                                                                                             
  +-sun.misc.Launcher$ExtClassLoader@232204a1                                                                                                                                                                                           

Location:                                                                                                                                                                                                                               
/home/ems/ems_eam/app/ems-eam-sysmanager-server-1.0-SNAPSHOT.jar                                                                                                                                                                        

        /*
         * WARNING - Removed try catching itself - possible behaviour change.
         */
        public static void executeTask(Long sysTaskId, Date nextTime) {
            try {
/*233*/         lock.writeLock().lock();
/*234*/         Long curTime = System.currentTimeMillis();
/*235*/         for (SmconfigDmTaskMain smconfigdmtaskmain : taskCache) {
/*237*/             if (!smconfigdmtaskmain.getSysTaskId().equals(sysTaskId)) continue;
/*240*/             if (smconfigdmtaskmain.getSysTaskEndTime() != null && smconfigdmtaskmain.getSysTaskEndTime().getTime() <= curTime) {
/*241*/                 smconfigdmtaskmain.setSysTaskState(SMTaskStatusEnum.PASTDUE.getCodeString());
/*242*/                 smconfigdmtaskmain.setTaskSwitch(SMTaskSwitchEnum.INVALID.getCode());
                    } else {
/*244*/                 smconfigdmtaskmain.setSysTaskState(SMTaskStatusEnum.EXECUTING.getCodeString());
/*245*/                 smconfigdmtaskmain.setTaskSwitch(SMTaskSwitchEnum.ACTIVE.getCode());
                    }
/*247*/             smconfigdmtaskmain.setSysTaskNextTime(nextTime);
                }
            }
            finally {
/*253*/         lock.writeLock().unlock();
            }
        }

Affect(row-cnt:1) cost in 1003 ms.
[arthas@24056]$
举例2:反编绎时只显示源代码(默认情况下,反编译结果里会带有ClassLoader信息)

默认情况下,反编译结果里会带有ClassLoader信息,通过--source-only选项,可以只打印源代码。方便和mc/retransform命令结合使用。

基本用法: jad --source-only 全路径类名 方法名

代码语言:java
复制
[arthas@24056]$ jad --source-only com.hero.lte.ems.sysmanager.cache.SMTaskCache executeTask
        /*
         * WARNING - Removed try catching itself - possible behaviour change.
         */
        public static void executeTask(Long sysTaskId, Date nextTime) {
            try {
/*233*/         lock.writeLock().lock();
/*234*/         Long curTime = System.currentTimeMillis();
/*235*/         for (SmconfigDmTaskMain smconfigdmtaskmain : taskCache) {
/*237*/             if (!smconfigdmtaskmain.getSysTaskId().equals(sysTaskId)) continue;
/*240*/             if (smconfigdmtaskmain.getSysTaskEndTime() != null && smconfigdmtaskmain.getSysTaskEndTime().getTime() <= curTime) {
/*241*/                 smconfigdmtaskmain.setSysTaskState(SMTaskStatusEnum.PASTDUE.getCodeString());
/*242*/                 smconfigdmtaskmain.setTaskSwitch(SMTaskSwitchEnum.INVALID.getCode());
                    } else {
/*244*/                 smconfigdmtaskmain.setSysTaskState(SMTaskStatusEnum.EXECUTING.getCodeString());
/*245*/                 smconfigdmtaskmain.setTaskSwitch(SMTaskSwitchEnum.ACTIVE.getCode());
                    }
/*247*/             smconfigdmtaskmain.setSysTaskNextTime(nextTime);
                }
            }
            finally {
/*253*/         lock.writeLock().unlock();
            }
        }

[arthas@24056]$ 
举例3:反编译时不显示行号

基本用法: jad --source-only 全路径类名 方法名 --lineNumber false

--lineNumber 参数默认值为 true,显示指定为 false 则不打印行号。

代码语言:java
复制
[arthas@24056]$ jad --source-only com.hero.lte.ems.sysmanager.cache.SMTaskCache executeTask --lineNumber false
/*
 * WARNING - Removed try catching itself - possible behaviour change.
 */
public static void executeTask(Long sysTaskId, Date nextTime) {
    try {
        lock.writeLock().lock();
        Long curTime = System.currentTimeMillis();
        for (SmconfigDmTaskMain smconfigdmtaskmain : taskCache) {
            if (!smconfigdmtaskmain.getSysTaskId().equals(sysTaskId)) continue;
            if (smconfigdmtaskmain.getSysTaskEndTime() != null && smconfigdmtaskmain.getSysTaskEndTime().getTime() <= curTime) {
                smconfigdmtaskmain.setSysTaskState(SMTaskStatusEnum.PASTDUE.getCodeString());
                smconfigdmtaskmain.setTaskSwitch(SMTaskSwitchEnum.INVALID.getCode());
            } else {
                smconfigdmtaskmain.setSysTaskState(SMTaskStatusEnum.EXECUTING.getCodeString());
                smconfigdmtaskmain.setTaskSwitch(SMTaskSwitchEnum.ACTIVE.getCode());
            }
            smconfigdmtaskmain.setSysTaskNextTime(nextTime);
        }
    }
    finally {
        lock.writeLock().unlock();
    }
}

[arthas@24056]$ 
举例4:反编译时指定 ClassLoader

提示:

当有多个 ClassLoader 都加载了这个类时,jad 命令会输出对应 ClassLoader 实例的 hashcode,然后你只需要重新执行 jad 命令,并使用参数 -c <hashcode> 就可以反编译指定 ClassLoader 加载的那个类了;

基本用法: jad 全路径类名

代码语言:java
复制
$ jad org.apache.log4j.Logger

Found more than one class for: org.apache.log4j.Logger, Please use jad -c hashcode org.apache.log4j.Logger
HASHCODE  CLASSLOADER
69dcaba4  +-monitor's ModuleClassLoader
6e51ad67  +-java.net.URLClassLoader@6e51ad67
            +-sun.misc.Launcher$AppClassLoader@6951a712
            +-sun.misc.Launcher$ExtClassLoader@6fafc4c2
2bdd9114  +-pandora-qos-service's ModuleClassLoader
4c0df5f8  +-pandora-framework's ModuleClassLoader

Affect(row-cnt:0) cost in 38 ms.
$ jad org.apache.log4j.Logger -c 69dcaba4

ClassLoader:
+-monitor's ModuleClassLoader

Location:
/Users/admin/app/log4j-1.2.14.jar

package org.apache.log4j;

import org.apache.log4j.spi.*;

public class Logger extends Category
{
    private static final String FQCN;

    protected Logger(String name)
    {
        super(name);
    }

...

Affect(row-cnt:1) cost in 190 ms.

对于只有唯一实例的 ClassLoader 还可以通过--classLoaderClass指定 class name,使用起来更加方便:

--classLoaderClass 的值是 ClassLoader 的类名,只有匹配到唯一的 ClassLoader 实例时才能工作,目的是方便输入通用命令,而-c <hashcode>是动态变化的。

本人其他相关文章链接

1.Arthas 全攻略:让调试变得简单

2.Arthas dashboard(当前系统的实时数据面板)

3.Arthas thread(查看当前JVM的线程堆栈信息)

4.Arthas jvm(查看当前JVM的信息)

5.Arthas sysprop(查看和修改JVM的系统属性)

6.Arthas sysenv(查看JVM的环境变量)

7.Arthas vmoption(查看和修改 JVM里诊断相关的option)

8.Arthas getstatic(查看类的静态属性 )

9.Arthas heapdump(dump java heap, 类似 jmap 命令的 heap dump 功能)

10.Arthas logger(查看 logger 信息,更新 logger level)

11.Arthas mbean(查看 Mbean 的信息)

12.Arthas memory(查看 JVM 内存信息)

13.Arthas ognl(执行ognl表达式)

14.Arthas perfcounter(查看当前 JVM 的 Perf Counter 信息)

15.Arthas vmtool(从 jvm 里查询对象,执行 forceGc)

16.Arthas jad(字节码文件反编译成源代码 )

17.Arthas mc(Memory Compiler/内存编译器 )

18.Arthas redefine(加载外部的.class文件,redefine到JVM里 )

19.Arthas classloader (查看 classloader 的继承树,urls,类加载信息)

20.Arthas sc(查看JVM已加载的类信息 )

21.Arthas sm(查看已加载类的方法信息 )

22.Arthas monitor(方法执行监控)

23.Arthas stack (输出当前方法被调用的调用路径)

24.Arthas trace (方法内部调用路径,并输出方法路径上的每个节点上耗时)

25.Arthas tt(方法执行数据的时空隧道,记录下指定方法每次调用的入参和返回信息,并能对这些不同的时间下调用进行观测)

26.Arthas watch (方法执行数据观测)

27.Arthas profiler(使用async-profiler对应用采样,生成火焰图)

原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。

如有侵权,请联系 cloudcommunity@tencent.com 删除。

原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。

如有侵权,请联系 cloudcommunity@tencent.com 删除。

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 二、命令列表
    • 2.2 class/classloader相关命令
      • 2.2.1 jad(字节码文件反编译成源代码 )
  • 本人其他相关文章链接
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档