一.打印输出
  • 在程序中输出使用频率很高,使用输出语句可以在程序执行过程中把一些结果输出到控制台中,程序员通过控制台中输出结果判断是否符合预期

  • 在Go语言中有多种输出方式,不同的输出适用场景不同.归纳起来三种,每种还分为3种方式(原内容,原内容+ln,原内容+f)

    • PrintXX()

    • FprintXX()

    • SprintXX()

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

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

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

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

    • Fprintln()输出后会添加换行符,所以长度比内容多1个

    • Fprintln()源码中p.doPrintln(a)的源码

// doPrintln is like doPrint but always adds a space between arguments
// and a newline after the last argument.
func (p *pp) doPrintln(a []interface{}) {
	for argNum, arg := range a {
		if argNum > 0 {
			p.buf.WriteByte(' ')
		}
		p.printArg(arg, 'v')
	}
	p.buf.WriteByte('\n')//此处多添加了换行
}

FprintXX()支持下面三种方式

  • os.Stdout 表示控制台输出流

func main() {
	fmt.Fprint(os.Stdout, "内容1")//向流中写入内容,多个内容之间没有空格
	fmt.Fprintln(os.Stdout, "内容2")//向流中写入内容后额外写入换行符,多个内容之间空格分割
	fmt.Fprintf(os.Stdout, "%s", "内容3")//根据verb格式向流中写入内容
}
三.PrintXX
  • PrintXX支持下面三种方式

func main() {
	fmt.Println("内容","内容")//输出内容后换行
	fmt.Print("内容","内容")//输出内容后不换行
	fmt.Printf("verb","内容")//根据verb输出指定格式内容
}

verb格式化动作对应的释义 

以Println()举例,源码如下

// Println formats using the default formats for its operands and writes to standard output.
// Spaces are always added between operands and a newline is appended.
// It returns the number of bytes written and any write error encountered.
func Println(a ...interface{}) (n int, err error) {
	return Fprintln(os.Stdout, a...)
}

可以看出Println()底层实际是Fprintln(),返回值依然是内容长度和错误信息

四.SPrintXX
  • 以Sprintln()举例,和Println()主要的区别是:

    • Sprintln()把形成结果以字符串返回,并没有打印到控制台

    • Println()把结果打印到控制台,返回内容长度和错误

  • 所以从严格意义角度讲SprintXX不是打印输出,而更像字符串转换

  • 源码如下

// Sprintln formats using the default formats for its operands and returns the resulting string.
// Spaces are always added between operands and a newline is appended.
func Sprintln(a ...interface{}) string {
	p := newPrinter()
	p.doPrintln(a)
	s := string(p.buf)
	p.free()
	return s
}

依然支持三种写法

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

import "fmt"

func main() {

	var Index string="helloworld";
	sprintf := fmt.Sprintf("%x", Index)
	fmt.Println(sprintf)
}