4

根据几个小组的帖子,以下代码应该可以工作:

package main

import "fmt"

func demo(format string, args ...interface{}) {
  var count = len(args)
  for i := 0; i < count; i++ {
    fmt.Printf("! %s\n", args[i])
  }
  fmt.Printf("%+v\n", format)
  fmt.Printf("%+v\n", args)
  fmt.Printf(format, args)
  fmt.Printf("\n")
}

func main() {
  demo("%s %d", "Hello World", 10)
  fmt.Printf("\n\n")
  demo("%d %s", 10, "Hello")
}

并产生“Hello World 10”和“10 Hello”,但它没有。相反,它产生:

! Hello World
! %!s(int=10)
%s %d
[Hello World 10]
[Hello World %!s(int=10)] %d(MISSING)


! %!s(int=10)
! Hello
%d %s
[10 Hello]
[10 %!d(string=Hello)] %s(MISSING)

也就是说,将 []interface{} 传递给以 ...interface{} 作为参数的函数不会扩展参数,而只是将其作为值传递。第一个 %s 将 []interface{} 扩展为字符串,不再处理任何参数。

我敢肯定在日志记录中必须有很多情况需要这样做;但我找不到任何可行的例子来说明如何做到这一点。

这基本上是 C 中的“vprintf”系列函数。

4

2 回答 2

10

我认为 OP 程序不应该“工作”。也许这是有意的(?):

package main

import "fmt"

func demo(format string, args ...interface{}) {
        fmt.Printf(format, args...)
}

func main() {
        demo("%s %d\n\n", "Hello World", 10)
        demo("%d %s", 10, "Hello")
}

(也在这里


输出:

Hello World 10

10 Hello
于 2013-02-06T13:37:31.200 回答
4

fmt.Printf(format, args...)我认为应该做你想做的事。

于 2013-02-06T13:38:09.950 回答