zoukankan      html  css  js  c++  java
  • Go: Println 与 Printf 的区别

    Go 学习笔记:Println 与 Printf 的区别,以及 Printf 的详细用法

    版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
    本文链接:https://blog.csdn.net/zgh0711/article/details/78843361

    Println 与Printf 都是fmt 包中的公共方法,在需要打印信息时需要用到这二个函数,那么这二个函数有什么区别呢?

    Println :可以打印出字符串,和变量
    Printf : 只可以打印出格式化的字符串,可以输出字符串类型的变量,不可以输出整形变量和整形

    也就是说,当需要格式化输出信息时一般选择 Printf,其他时候用 Println 就可以了,比如:

    a := 10
    fmt.Println(a)  //right
    fmt.Println("abc")  //right
    fmt.Printf("%d",a)  //right
    fmt.Printf(a)  //error
    • 1
    • 2
    • 3
    • 4
    • 5

    Printf 详细用法

    Printf 在使用时需要给它指定一个格式化规则,即第一个参数,那么一共有多少种格式呢,用的时候需要怎么写呢?

    package main
    import "fmt"
    import "os"
    type point struct {
        x, y int
    }
    func main() {
        //Go 为常规 Go 值的格式化设计提供了多种打印方式。例如,这里打印了 point 结构体的一个实例。
        p := point{1, 2}
        fmt.Printf("%v
    ", p) // {1 2}
        //如果值是一个结构体,%+v 的格式化输出内容将包括结构体的字段名。
        fmt.Printf("%+v
    ", p) // {x:1 y:2}
        //%#v 形式则输出这个值的 Go 语法表示。例如,值的运行源代码片段。
        fmt.Printf("%#v
    ", p) // main.point{x:1, y:2}
        //需要打印值的类型,使用 %T。
        fmt.Printf("%T
    ", p) // main.point
        //格式化布尔值是简单的。
        fmt.Printf("%t
    ", true)
        //格式化整形数有多种方式,使用 %d进行标准的十进制格式化。
        fmt.Printf("%d
    ", 123)
        //这个输出二进制表示形式。
        fmt.Printf("%b
    ", 14)
        //这个输出给定整数的对应字符。
        fmt.Printf("%c
    ", 33)
        //%x 提供十六进制编码。
        fmt.Printf("%x
    ", 456)
        //对于浮点型同样有很多的格式化选项。使用 %f 进行最基本的十进制格式化。
        fmt.Printf("%f
    ", 78.9)
        //%e 和 %E 将浮点型格式化为(稍微有一点不同的)科学技科学记数法表示形式。
        fmt.Printf("%e
    ", 123400000.0)
        fmt.Printf("%E
    ", 123400000.0)
        //使用 %s 进行基本的字符串输出。
        fmt.Printf("%s
    ", ""string"")
        //像 Go 源代码中那样带有双引号的输出,使用 %q。
        fmt.Printf("%q
    ", ""string"")
        //和上面的整形数一样,%x 输出使用 base-16 编码的字符串,每个字节使用 2 个字符表示。
        fmt.Printf("%x
    ", "hex this")
        //要输出一个指针的值,使用 %p。
        fmt.Printf("%p
    ", &p)
        //当输出数字的时候,你将经常想要控制输出结果的宽度和精度,可以使用在 % 后面使用数字来控制输出宽度。默认结果使用右对齐并且通过空格来填充空白部分。
        fmt.Printf("|%6d|%6d|
    ", 12, 345)
        //你也可以指定浮点型的输出宽度,同时也可以通过 宽度.精度 的语法来指定输出的精度。
        fmt.Printf("|%6.2f|%6.2f|
    ", 1.2, 3.45)
        //要最对齐,使用 - 标志。
        fmt.Printf("|%-6.2f|%-6.2f|
    ", 1.2, 3.45)
        //你也许也想控制字符串输出时的宽度,特别是要确保他们在类表格输出时的对齐。这是基本的右对齐宽度表示。
        fmt.Printf("|%6s|%6s|
    ", "foo", "b")
        //要左对齐,和数字一样,使用 - 标志。
        fmt.Printf("|%-6s|%-6s|
    ", "foo", "b")
        //到目前为止,我们已经看过 Printf了,它通过 os.Stdout输出格式化的字符串。Sprintf 则格式化并返回一个字符串而不带任何输出。
        s := fmt.Sprintf("a %s", "string")
        fmt.Println(s)
        //你可以使用 Fprintf 来格式化并输出到 io.Writers而不是 os.Stdout。
        fmt.Fprintf(os.Stderr, "an %s
    ", "error")
    }

    可以看到,这种类还是挺多的,但平时经常用的也就前面几种而已,或者可以说,用的最多的就是第一个,,,

  • 相关阅读:
    数组的Clone方法
    反射创建类的一种方法
    css比较容易搞混的三个选择器
    java8 引进lamda
    js动态创建的元素绑定事件
    【Alpha版本】项目测试
    第五次团队作业——【Alpha版本】随笔汇总
    【Alpha版本】项目总结
    【Alpha版本】冲刺阶段——Day 10
    【Alpha版本】冲刺阶段——Day 9
  • 原文地址:https://www.cnblogs.com/qiangyuzhou/p/11797032.html
Copyright © 2011-2022 走看看