被调试程序
@RestController
@RequestMapping("/ch4")
public class Ch4Controller {
@RequestMapping("/arg1")
public String arg1(@RequestParam("name") String name) {
return "hello," + name;
}
@RequestMapping("/arg2")
public User arg2(User user) {
return user;
}
@RequestMapping("/constructor")
public User constructor(User user) {
return user;
}
@RequestMapping("/same1")
public String same(@RequestParam("name")String name) {
return "hello,"+name;
}
@RequestMapping("/same2")
public String same(@RequestParam("name")String name,@RequestParam("id")int id) {
return "hello,"+name+","+id;
}
@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脚本
package com.btrace.example;
import com.sun.btrace.BTraceUtils;
import com.sun.btrace.annotations.BTrace;
import com.sun.btrace.annotations.OnMethod;
import com.sun.btrace.annotations.ProbeClassName;
import com.sun.btrace.annotations.ProbeMethodName;
@BTrace
public class PrintRegex {
@OnMethod(
clazz="com.example.demo.btrace.Ch4Controller",
method="/.*/"
)
public static void anyRead(@ProbeClassName String pcn, @ProbeMethodName String pmn) {
BTraceUtils.println(pcn + ", " + pmn);
BTraceUtils.println();
}
}