Go 中 log.Printf 方法如何正确处理可变参数?

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 方法如何正确处理可变参数?的详细内容,更多请关注其它相关文章!