一.打印输出
- 在程序中输出使用频率很高,使用输出语句可以在程序执行过程中把一些结果输出到控制台中,程序员通过控制台中输出结果判断是否符合预期
在Go语言中有多种输出方式,不同的输出适用场景不同.归纳起来三种,每种还分为3种方式(原内容,原内容+ln,原内容+f)
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格式向流中写入内容}
- os.Stdout 表示控制台输出流
三.PrintXX
PrintXX支持下面三种方式
func main() {fmt.Println("内容","内容")//输出内容后换行fmt.Print("内容","内容")//输出内容后不换行fmt.Printf("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")}
