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