小编Spl*_*ked的帖子

如何使用"... interface {}"参数包装函数(如Printf)

在我当前的项目中,我正在尝试编写一个有条件地调用fmt.Println的日志记录函数.

我当前的Log函数如下所示:

func Log(level int, a ...interface{}) {
    if level <= LogLevel {
        fmt.Println(a)
    }
}
Run Code Online (Sandbox Code Playgroud)

但是当我这样称它时,由于某种原因,Log的输出被括在括号中:

http://play.golang.org/p/Aa8vC54Ih0

package main

import "fmt"

var LogLevel int

func main() {
    fmt.Println("string", 10, 3.1415926)
    LogLevel = 1
    Log(1, "string", 10, 3.1415926)
}

func Log(level int, a ...interface{}) {
    if level <= LogLevel {
        fmt.Println(a)
    }
}

string 10 3.1415926
[string 10 3.1415926]
Run Code Online (Sandbox Code Playgroud)

这对我看起来像aLog中的参数以某种方式被转换.我将如何以a与直接调用fmt.Println相同的方式传递给fmt.Println?

go

11
推荐指数
1
解决办法
3219
查看次数

标签 统计

go ×1