被调试程序
@RestController
@RequestMapping("/ch4")
public class Ch4Controller {
@RequestMapping("/exception")
public String exception() {
try {
System.out.println("start...");
System.out.println(1/0);
System.out.println("end...");
}catch(Exception e) {
//
}
return "success";
}
}
BTrace脚本
- 如果Ch4Controller的exception()方法的40行执行了,则line的值为40;
package com.btrace.example;
import com.sun.btrace.BTraceUtils;
import com.sun.btrace.annotations.BTrace;
import com.sun.btrace.annotations.Kind;
import com.sun.btrace.annotations.Location;
import com.sun.btrace.annotations.OnMethod;
import com.sun.btrace.annotations.ProbeClassName;
import com.sun.btrace.annotations.ProbeMethodName;
@BTrace
public class PrintLine {
@OnMethod(
clazz="com.example.demo.btrace.Ch4Controller",
method="exception",
location=@Location(value=Kind.LINE, line=40)
)
public static void anyRead(@ProbeClassName String pcn, @ProbeMethodName String pmn, int line) {
BTraceUtils.println(pcn + ", " + pmn + "," + line);
BTraceUtils.println();
}
}