一.打印输出

  • 在程序中输出使用频率很高,使用输出语句可以在程序执行过程中把一些结果输出到控制台中,程序员通过控制台中输出结果判断是否符合预期
  • 在Go语言中有多种输出方式,不同的输出适用场景不同.归纳起来三种,每种还分为3种方式(原内容,原内容+ln,原内容+f)

    • PrintXX()
    • FprintXX()
    • SprintXX()

      二.FprintXX

  • FprintXX在Go Web中使用比较多,把内容写到响应流中.

  • 以Fprintln()举例,源码如下

    1. // Fprintln formats using the default formats for its operands and writes to w.
    2. // Spaces are always added between operands and a newline is appended.
    3. // It returns the number of bytes written and any write error encountered.
    4. func Fprintln(w io.Writer, a ...interface{}) (n int, err error) {
    5. p := newPrinter()
    6. p.doPrintln(a)
    7. n, err = w.Write(p.buf)
    8. p.free()
    9. return
    10. }
  • 函数参数中第一个参数是输出流,后面参数是内容,表示把内容写入到输出流中

  • 第一个返回值表示输出内容长度(字节数),第二个返回值表示错误,如果没有错误取值nil

    • Fprintln()输出后会添加换行符,所以长度比内容多1个
    • Fprintln()源码中p.doPrintln(a)的源码
      1. // doPrintln is like doPrint but always adds a space between arguments
      2. // and a newline after the last argument.
      3. func (p *pp) doPrintln(a []interface{}) {
      4. for argNum, arg := range a {
      5. if argNum > 0 {
      6. p.buf.WriteByte(' ')
      7. }
      8. p.printArg(arg, 'v')
      9. }
      10. p.buf.WriteByte('\n')//此处多添加了换行
      11. }
  • FprintXX()支持下面三种方式

    • os.Stdout 表示控制台输出流
      1. func main() {
      2. fmt.Fprint(os.Stdout, "内容1")//向流中写入内容,多个内容之间没有空格
      3. fmt.Fprintln(os.Stdout, "内容2")//向流中写入内容后额外写入换行符,多个内容之间空格分割
      4. fmt.Fprintf(os.Stdout, "%s", "内容3")//根据verb格式向流中写入内容
      5. }

三.PrintXX

  • PrintXX支持下面三种方式

    1. func main() {
    2. fmt.Println("内容","内容")//输出内容后换行
    3. fmt.Print("内容","内容")//输出内容后不换行
    4. fmt.Printf("verb","内容")//根据verb输出指定格式内容
    5. }
  • 以Println()举例,源码如下

    1. // Println formats using the default formats for its operands and writes to standard output.
    2. // Spaces are always added between operands and a newline is appended.
    3. // It returns the number of bytes written and any write error encountered.
    4. func Println(a ...interface{}) (n int, err error) {
    5. return Fprintln(os.Stdout, a...)
    6. }
  • 可以看出Println()底层实际是Fprintln(),返回值依然是内容长度和错误信息

四.SPrintXX

  • 以Sprintln()举例,和Println()主要的区别是:
    • Sprintln()把形成结果以字符串返回,并没有打印到控制台
    • Println()把结果打印到控制台,返回内容长度和错误
  • 所以从严格意义角度讲SprintXX不是打印输出,而更像字符串转换
  • 源码如下

    1. // Sprintln formats using the default formats for its operands and returns the resulting string.
    2. // Spaces are always added between operands and a newline is appended.
    3. func Sprintln(a ...interface{}) string {
    4. p := newPrinter()
    5. p.doPrintln(a)
    6. s := string(p.buf)
    7. p.free()
    8. return s
    9. }
  • 依然支持三种写法

    1. func main() {
    2. fmt.Sprint("内容1", "内容12")
    3. fmt.Sprintln("内容2")
    4. fmt.Sprintf("%s", "内容3")
    5. }