Go 最直接的debug 方式 輸出函式

zhaocrazy發表於2021-12-13

初學go,最直接的debug 方式就是:用fmt 包 根據執行流程直接用輸出函式列印

package main
import "fmt"
import "os"
type point struct {
    a, b int
}
func main() {
    //Go 為常規 Go 值的格式化設計提供了多種列印方式。
    p := point{1, 2}
    fmt.Printf("%v\n", p) // {1 2}

    //如果值是一個結構體,%+v 的格式化輸出內容將包括結構體的欄位名。
    fmt.Printf("%+v\n", p) // {a:1 b:2}

    //%#v 形式則輸出這個值的 Go 語法表示。例如,值的執行原始碼片段。
    fmt.Printf("%#v\n", p) // main.point{x:1, y:2}

    //需要列印值的型別,使用 %T。
    fmt.Printf("%T\n", p) // main.point

    //格式化布林值是簡單的。
    fmt.Printf("%t\n", true)   // true

    //格式化整形數有多種方式,使用 %d進行標準的十進位制格式化。
    fmt.Printf("%d\n", 123)  // 123

    //這個輸出二進位制表示形式。
    fmt.Printf("%b\n", 14) // 1110

    //這個輸出給定整數的對應字元。
    fmt.Printf("%c\n", 33) // !

    //%x 提供十六進位制編碼。
    fmt.Printf("%x\n", 456)  // 1c8

    //對於浮點型同樣有很多的格式化選項。使用 %f 進行最基本的十進位制格式化。
    fmt.Printf("%f\n", 78.9)  // 78.900000

    //%e 和 %E 將浮點型格式化為(稍微有一點不同的)科學技科學記數法表示形式。
    fmt.Printf("%e\n", 123400000.0) // 1.234000e+08
    fmt.Printf("%E\n", 123400000.0)  // 1.234000E+08

    //使用 %s 進行基本的字串輸出。
    fmt.Printf("%s\n", "\"string\"") // "string"

    //像 Go 原始碼中那樣帶有雙引號的輸出,使用 %q。
    fmt.Printf("%q\n", "\"string\"") // "\"string\""

    //和上面的整形數一樣,%x 輸出使用 base-16 編碼的字串,每個位元組使用 2 個字元表示。
    fmt.Printf("%x\n", "hex this")  //  6865782074686973

    //要輸出一個指標的值,使用 %p。
    fmt.Printf("%p\n", &p)   // 0xc0000160b0

    //當輸出數字的時候,你將經常想要控制輸出結果的寬度和精度,可以使用在 % 後面使用數字來控制輸出寬度。預設結果使用右對齊並且通過空格來填充空白部分。
    fmt.Printf("|%6d|%6d|\n", 12, 345)  // |    12|   345|

    //你也可以指定浮點型的輸出寬度,同時也可以通過 寬度.精度 的語法來指定輸出的精度。
    fmt.Printf("|%6.2f|%6.2f|\n", 1.2, 3.45) // |  1.20|  3.45|

    //要最對齊,使用 - 標誌。
    fmt.Printf("|%-6.2f|%-6.2f|\n", 1.2, 3.45) // |1.20  |3.45  |

    //你也許也想控制字串輸出時的寬度,特別是要確保他們在類表格輸出時的對齊。這是基本的右對齊寬度表示。
    fmt.Printf("|%6s|%6s|\n", "foo", "b") // |   foo|     b|

    //要左對齊,和數字一樣,使用 - 標誌。
    fmt.Printf("|%-6s|%-6s|\n", "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\n", "error") // an error
}

go 1.15 centos7.4 執行結果

{1 2}
{a:1 b:2}
main.point{a:1, b:2}
main.point
true
123
1110
!
1c8
78.900000
1.234000e+08
1.234000E+08
"string"
"\"string\""
6865782074686973
0xc0000160b0
|    12|   345|
|  1.20|  3.45|
|1.20  |3.45  |
|   foo|     b|
|foo   |b     |
a string
an error
本作品採用《CC 協議》,轉載必須註明作者和本文連結
左手寫詩 右手程式碼

相關文章