zoukankan      html  css  js  c++  java
  • Golang | 扩展

    Golang | 扩展 - 1. Println 与 Printf 的区别

    目录:

    fmt包实现了格式化的I/O,其功能类似于C的printfscanf

    1. 概括

    • Println

      1. 用默认的类型格式显示方式将传入的参数写入标准输出里面(即在终端中有显示);
      2. 多个传入参数之间使用口空格分割;
      3. 在显示的最后追加换行符;
      4. 返回值为 写入标准输出的字节数和写入过程中遇到的问题;
    • Printf

      1. 用传入的格式化规则符将传入的变量写入到标准输出里面(即在终端中有显示);
      2. 返回值为 写入标准输出的字节数和写入过程中遇到的问题;
    • Sprintf

      1. 用传入的格式化规则符将传入的变量格式化(即在终端中不会有显示);
      2. 返回值为 格式化后的字符串;
    • Println:可以打印出字符串,和变量;

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

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

    a := 10 
    fmt.Println(a)  //right 
    fmt.Println("abc")  //right 
    fmt.Printf("%d",a)  //right 
    fmt.Printf(a)  //error
    

    2. 例子

    2.1 Print 和 Println

    1. Println 打印的每一项之间都会有空行,Print 没有,例如:
    fmt.Println("go","python","php","javascript") // go python php javascript
    fmt.Print("go","python","php","javascript") // gopythonphpjavascript
    
    1. Println 会自动换行,Print 不会,例如:
    fmt.Println("hello")
    fmt.Println("world")
    
    // hello
    // world
    
    // -----------------------------------
    
    fmt.Print("hello")
    fmt.Print("world")
    
    // helloworld
    

    3. Printf详细用法

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

    
    package main
    import (
        "fmt"
        "os"
    )
    
    type point struct {
        x, y int
    }
    
    func main() {
        // Go 为常规 Go 值的格式化设计提供了多种打印方式。
        p := point{1, 2}
        
        // 例如,这里打印了 point 结构体的一个实例。
        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) // true
        
        // 格式化整形数有多种方式,使用 %d进行标准的十进制格式化。
        fmt.Printf("%d
    ", 123) // 123
        
        // 这个输出二进制表示形式。
        fmt.Printf("%b
    ", 14) // 1110
        
        // 这个输出给定整数的对应字符。
        fmt.Printf("%c
    ", 50) // 2
        
        // %x 提供十六进制编码。
        fmt.Printf("%x
    ", 456) //1c8
        
        // 对于浮点型同样有很多的格式化选项。使用 %f 进行最基本的十进制格式化。
        fmt.Printf("%f
    ", 78.9) // 78.900000
        
        // %e 和 %E 将浮点型格式化为科学记数法表示形式(两者有些不同)。
        fmt.Printf("%e
    ", 123400000.0) // 1.234000e+08
        fmt.Printf("%E
    ", 123400000.0) // 1.234000E+08
        
        // 使用 %s 进行基本的字符串输出。
        fmt.Printf("%s
    ", ""string"") // "string"
        
        // 像 Go 源代码中那样带有双引号的输出,使用 %q。
        fmt.Printf("%q
    ", "string") // "string"
        
        // 和上面的整形数一样,%x 输出使用 base-16 编码的字符串,每个字节使用 2 个字符表示。
        fmt.Printf("%x
    ", "hex this") // 6865782074686973
        
        // 要输出一个指针的值,使用 %p。
        fmt.Printf("%p
    ", &p) // 0xc0000b6010
        
        // 当输出数字的时候,你将经常想要控制输出结果的宽度和精度,可以使用在 % 后面使用数字来控制输出宽度。默认结果使用右对齐并且通过空格来填充空白部分。
        fmt.Printf("|%6d|%6d|
    ", 12, 345) // |    12|   345|
        
        // 你也可以指定浮点型的输出宽度,同时也可以通过 宽度.精度 的语法来指定输出的精度。
        fmt.Printf("|%6.2f|%6.2f|
    ", 1.2, 3.45) // |  1.20|  3.45|
        
        // 要最左对齐,使用 - 标志。
        fmt.Printf("|%-6.2f|%-6.2f|
    ", 1.2, 3.45) // |1.20  |3.45  |
        
        // 你也许也想控制字符串输出时的宽度,特别是要确保他们在类表格输出时的对齐。这是基本的右对齐宽度表示。
        fmt.Printf("|%6s|%6s|
    ", "foo", "b") // |   foo|     b|
        
        // 要左对齐,和数字一样,使用 - 标志。
        fmt.Printf("|%-6s|%-6s|
    ", "foo", "b") // |foo   |b     |
        
        // 到目前为止,我们已经看过 Printf了,它通过 os.Stdout输出格式化的字符串。Sprintf 则格式化并返回一个字符串而不带任何输出。
        s := fmt.Sprintf("a %s", "string")
        fmt.Println(s) // a string
        
        // 你可以使用 Fprintf 来格式化并输出到 io.Writers而不是 os.Stdout。
        fmt.Fprintf(os.Stderr, "an %s
    ", "error") // an error
    }
    
  • 相关阅读:
    uni-app 发起请求,Toast 消息提示 ,跳转页面
    uView初识
    uni-app初识
    docker目录 /var/lib/docker/containers 日志清理
    Linux中使用pigz工具更快的压缩和解压文件
    docker 修改默认网段
    LayaAir提示:版本不匹配!全局tsc(2.7.2)!=VS Code的语言服务(2.1.5)。可能出现不一致的编译错误
    C++ 格式化 浮点为字符串
    安装 ta-lib
    编译 python 代码
  • 原文地址:https://www.cnblogs.com/jeremy-zhang/p/13082800.html
Copyright © 2011-2022 走看看