> 查看JVM已加载的类信息 “Search-Class” 的简写,这个命令能搜索出所有已经加载到 JVM 中的 Class 信息,这个命令支持的参数有 `[d]`、`[E]`、`[f]` 和 `[x:]`。 参数说明 --- ### 参数说明 |参数名称|参数说明| |---:|:---| |*class-pattern*|类名表达式匹配| |*method-pattern*|方法名表达式匹配| |[d]|输出当前类的详细信息,包括这个类所加载的原始文件来源、类的声明、加载的ClassLoader等详细信息。
如果一个类被多个ClassLoader所加载,则会出现多次| |[E]|开启正则表达式匹配,默认为通配符匹配| |[f]|输出当前类的成员变量信息(需要配合参数-d一起使用)| |[x:]|指定输出静态变量时属性的遍历深度,默认为 0,即直接使用 `toString` 输出| |`[c:]`|指定class的 ClassLoader 的 hashcode| |`[classLoaderClass:]`|指定执行表达式的 ClassLoader 的 class name| |`[n:]`|具有详细信息的匹配类的最大数量(默认为100)| > class-pattern支持全限定名,如com.taobao.test.AAA,也支持com/taobao/test/AAA这样的格式,这样,我们从异常堆栈里面把类名拷贝过来的时候,不需要在手动把`/`替换为`.`啦。 > sc 默认开启了子类匹配功能,也就是说所有当前类的子类也会被搜索出来,想要精确的匹配,请打开`options disable-sub-class true`开关 ### 使用参考 * 模糊搜索 `sc demo.*`{{execute T2}} ```bash $ sc demo.* demo.MathGame Affect(row-cnt:1) cost in 55 ms. ``` * 打印类的详细信息 `sc -d demo.MathGame`{{execute T2}} ```bash $ sc -d demo.MathGame class-info demo.MathGame code-source /private/tmp/math-game.jar name demo.MathGame isInterface false isAnnotation false isEnum false isAnonymousClass false isArray false isLocalClass false isMemberClass false isPrimitive false isSynthetic false simple-name MathGame modifier public annotation interfaces super-class +-java.lang.Object class-loader +-sun.misc.Launcher$AppClassLoader@3d4eac69 +-sun.misc.Launcher$ExtClassLoader@66350f69 classLoaderHash 3d4eac69 Affect(row-cnt:1) cost in 875 ms. ``` * 指定classLoader 注意hashcode是变化的,需要先查看当前的ClassLoader信息,提取对应ClassLoader的hashcode。 如果你使用`-c`,你需要手动输入hashcode:`-c ` ```bash $ sc -c 3d4eac69 -d demo* ``` 对于只有唯一实例的ClassLoader可以通过`--classLoaderClass`指定class name,使用起来更加方便: `sc --classLoaderClass sun.misc.Launcher$AppClassLoader -d demo*`{{execute T2}} * 注: 这里classLoaderClass 在 java 8 是 sun.misc.Launcher$AppClassLoader,而java 11的classloader是jdk.internal.loader.ClassLoaders$AppClassLoader,katacoda目前环境是java8。 `--classLoaderClass` 的值是ClassLoader的类名,只有匹配到唯一的ClassLoader实例时才能工作,目的是方便输入通用命令,而`-c `是动态变化的。 * 打印出类的Field信息 `sc -d -f demo.MathGame`{{execute T2}} ```bash $ sc -d -f demo.MathGame class-info demo.MathGame code-source /private/tmp/math-game.jar name demo.MathGame isInterface false isAnnotation false isEnum false isAnonymousClass false isArray false isLocalClass false isMemberClass false isPrimitive false isSynthetic false simple-name MathGame modifier public annotation interfaces super-class +-java.lang.Object class-loader +-sun.misc.Launcher$AppClassLoader@3d4eac69 +-sun.misc.Launcher$ExtClassLoader@66350f69 classLoaderHash 3d4eac69 fields modifierprivate,static type java.util.Random name random value java.util.Random@522b4 08a modifierprivate type int name illegalArgumentCount Affect(row-cnt:1) cost in 19 ms. ```