printf 在使用時需要給它指定乙個格式化規則,下面就詳細列舉一下他的用法
package main
import "fmt"
import "os"
type point struct
func main()
fmt.printf("%v\n", p) //
//如果值是乙個結構體,%+v 的格式化輸出內容將包括結構體的欄位名。
fmt.printf("%+v\n", p) //
//%#v 形式則輸出這個值的 go 語法表示。例如,值的執行源**片段。
fmt.printf("%#v\n", p) // main.point
//需要列印值的型別,使用 %t。
fmt.printf("%t\n", p) // main.point
//格式化布林值是簡單的。
fmt.printf("%t\n", true)
//格式化整形數有多種方式,使用 %d進行標準的十進位制格式化。
fmt.printf("%d\n", 123)
//這個輸出二進位制表示形式。
fmt.printf("%b\n", 14)
//這個輸出給定整數的對應字元。
fmt.printf("%c\n", 33)
//%x 提供十六進製制編碼。
fmt.printf("%x\n", 456)
//對於浮點型同樣有很多的格式化選項。使用 %f 進行最基本的十進位制格式化。
fmt.printf("%f\n", 78.9)
//%e 和 %e 將浮點型格式化為(稍微有一點不同的)科學技科學記數法表示形式。
fmt.printf("%e\n", 123400000.0)
fmt.printf("%e\n", 123400000.0)
//使用 %s 進行基本的字串輸出。
fmt.printf("%s\n", "\"string\"")
//像 go 源**中那樣帶有雙引號的輸出,使用 %q。
fmt.printf("%q\n", "\"string\"")
//和上面的整形數一樣,%x 輸出使用 base-16 編碼的字串,每個位元組使用 2 個字元表示。
fmt.printf("%x\n", "hex this")
//要輸出乙個指標的值,使用 %p。
fmt.printf("%p\n", &p)
//當輸出數字的時候,你將經常想要控制輸出結果的寬度和精度,可以使用在 % 後面使用數字來控制輸出寬度。預設結果使用右對齊並且通過空格來填充空白部分。
fmt.printf("|%6d|%6d|\n", 12, 345)
//你也可以指定浮點型的輸出寬度,同時也可以通過 寬度.精度 的語法來指定輸出的精度。
fmt.printf("|%6.2f|%6.2f|\n", 1.2, 3.45)
//要最對齊,使用 - 標誌。
fmt.printf("|%-6.2f|%-6.2f|\n", 1.2, 3.45)
//你也許也想控制字串輸出時的寬度,特別是要確保他們在類**輸出時的對齊。這是基本的右對齊寬度表示。
fmt.printf("|%6s|%6s|\n", "foo", "b")
//要左對齊,和數字一樣,使用 - 標誌。
fmt.printf("|%-6s|%-6s|\n", "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\n", "error")
}
go語言中linkname的用法
在go語言的原始碼中,會發現很多,只有函式簽名,卻看不到函式體,如 src os proc.go 68行 func runtime beforeexit implemented in runtime 此處我們只看到函式簽名,卻看不到函式體,全域性搜了一把,發現它的函式體卻定義在src runtime...
go語言中strings的用法技巧
strings.hasprefix s string,prefix string bool 判斷字串s是否以prefix開頭 strings.hassuffix s string,suffix string bool 判斷字串s是否以suffix結尾。strings.index s string,s...
Go 語言中 Unsafe 包的用法
後端早讀課翻譯計畫 第三篇 翻譯自 a journey with go 本文列舉在 golang 中 unsafe 的一般用法,以及提供給開發者的一些建議。本文基於 go 1.12 版本。這個 package 的名字其實已經告訴了我們,我們不應該用它。為了弄清楚為什麼用它會導致不安全,我們先看下文件...