fmt包主要是實現了格式化的I/O函數ide
fmt.Println() 行打印函數
fmt.Printf() 格式化輸出ui
%d intspa
%s str3d
%t type,類型指針
%p 內存地址code
%v 獲取變量的值blog
%o 控制8進制輸出索引
%x 控制16進制輸出內存
%c 打印參數
%q 打印帶引號的字符
i := 'a' j := '重' fmt.Printf("%d %[1]c %[1]q\n",i) fmt.Printf("%d %[1]c %[1]q\n",j) //97 a 'a' //37325 重 '重'
fmt.Scan() 掃描輸入的文本
const 申明常量,一旦申明不可更改。其類型只能是數字,字符串或者布爾值
package main import "fmt" func main() { const LENGTH int = 10 const WIDTH int = 5 var area int const a, b, c = 1, false, "str" //多重賦值 area = LENGTH * WIDTH fmt.Printf("面積爲 : %d", area) println() println(a, b, c) } //運行結果 //面積爲 : 50 //1 false str
另外常量能夠用len(), cap(), unsafe.Sizeof()函數計算表達式的值。常量表達式中,函數必須是內置函數,不然編譯不過:
package main import "unsafe" const ( a = "abc" b = len(a) c = unsafe.Sizeof(a) ) func main(){ println(a, b, c) } //運行結果 //abc 3 16
a.unsafe.sizeof函數是用來計算結構體的空間大小,只返回數據類型的大小,無論引用數據的大小
b.string類型的不是直接存的數據,而是一個結構體,用指針指向實際數據地址
type StringHeader struct { Data uintptr Len int }
c.在64位系統上uintptr
int
都是8字節,加起來就16了。
iota 特殊常量,能夠認爲是一個能夠被編譯器修改的常量。
1.iota 在 const關鍵字出現時將被重置爲 0(const 內部的第一行以前)
2.const 中每新增一行常量聲明將使 iota 計數一次(iota 可理解爲 const 語句塊中的行索引)。
const ( a = iota b = iota c = iota )
const ( a = iota b c )
iota的用法
package main import "fmt" func main() { const ( a = iota //0 b //1 c //2 d = "ha" //獨立值,iota += 1 e //"ha" iota += 1 f = 100 //iota +=1 g //100 iota +=1 h = iota //7,恢復計數 i //8 ) fmt.Println(a,b,c,d,e,f,g,h,i) } //運行結果 //0 1 2 ha ha 100 100 7 8
iota有趣的實例
package main import "fmt" const ( i=1<<iota j=3<<iota k l ) func main() { fmt.Println("i=",i) fmt.Println("j=",j) fmt.Println("k=",k) fmt.Println("l=",l) } //運行結果 //i= 1 //j= 6 //k= 12 //l= 24
1.iota 表示從 0 開始自動加 1
2.因此 i=1<<0, j=3<<1(<< 表示左移的意思),即:i=1, j=6
3.關鍵在 k 和 l,從輸出結果看 k=3<<2,l=3<<3
解析:
a. i = 1 ; 左移 0 位,不變仍爲 1
b. j = 3; 左移 1 位,變爲二進制 110, 即 6
c. k = 3; 左移 2 位,變爲二進制 1100, 即 12
d. l = 3; 左移 3 位,變爲二進制 11000,即 24