
go 中封装 log.printf 方法遇到的问题
想要控制日志输出,您尝试封装了 log 相关的方法,但在使用 log.printf 时遇到了问题。
问题详情:
func debugf(str string, arg ...interface{}) {
if true {
log.printf(str+"\n", arg)
}
}您期望输出:"我叫jim,今年18",但实际输出为:"我叫[jim %!s(int=18)],今年%!d(missing)"。原因在于 log.printf 的第 2 个参数是可变参数,需要使用 ... 来展开它。
问题解决方案:
修改代码为:
func Debugf(str string, arg ...interface{}) {
if true {
log.Printf(str+"\n", arg...)
}
}这样就会正确输出您期望的内容。










