本文實例分析了Go語言中的指針運算方法。分享給大家供大家參考。具體分析如下:
Go語言的語法上是不支持指針運算的,所有指針都在可控的一個范圍內使用,沒有C語言的*void然后隨意轉換指針類型這樣的東西。最近在思考Go如何操作共享內存,共享內存就需要把指針轉成不同類型或者對指針進行運算再獲取數據。
這里對Go語言內置的unsafe模塊做了一個實驗,發現通過unsafe模塊,Go語言一樣可以做指針運算,只是比C的方式繁瑣一些,但是理解上是一樣的。
下面是實驗代碼:
復制代碼 代碼如下:
package main
import "fmt"
import "unsafe"
type Data struct {
Col1 byte
Col2 int
Col3 string
Col4 int
}
func main() {
var v Data
fmt.Println(unsafe.Sizeof(v))
fmt.Println("----")
fmt.Println(unsafe.Alignof(v.Col1))
fmt.Println(unsafe.Alignof(v.Col2))
fmt.Println(unsafe.Alignof(v.Col3))
fmt.Println(unsafe.Alignof(v.Col4))
fmt.Println("----")
fmt.Println(unsafe.Offsetof(v.Col1))
fmt.Println(unsafe.Offsetof(v.Col2))
fmt.Println(unsafe.Offsetof(v.Col3))
fmt.Println(unsafe.Offsetof(v.Col4))
fmt.Println("----")
v.Col1 = 98
v.Col2 = 77
v.Col3 = "1234567890abcdef"
v.Col4 = 23
fmt.Println(unsafe.Sizeof(v))
fmt.Println("----")
x := unsafe.Pointer(v)
fmt.Println(*(*byte)(x))
fmt.Println(*(*int)(unsafe.Pointer(uintptr(x) + unsafe.Offsetof(v.Col2))))
fmt.Println(*(*string)(unsafe.Pointer(uintptr(x) + unsafe.Offsetof(v.Col3))))
fmt.Println(*(*int)(unsafe.Pointer(uintptr(x) + unsafe.Offsetof(v.Col4))))
}
以上代碼在我機器上的執行結果如下(結果會因機器和系統的不同而不太一樣):
32
----
1
4
8
4
----
0
4
8
24
----
32
----
98
77
1234567890abcdef
23
unsafe模塊的文檔中提到幾條轉換規則,理解了以后就很容易做指針運算了:
A pointer value of any type can be converted to a Pointer.
A Pointer can be converted to a pointer value of any type.
A uintptr can be converted to a Pointer.
A Pointer can be converted to a uintptr.
希望本文所述對大家的Go語言程序設計有所幫助。
您可能感興趣的文章:- Go語言應該什么情況使用指針
- 關于Golang中range指針數據的坑詳解
- Go 語言的指針的學習筆記
- Go語言中結構體方法副本傳參與指針傳參的區別介紹
- golang中值類型/指針類型的變量區別總結
- golang方法中receiver為指針與不為指針的區別詳析
- Go語言指針訪問結構體的方法
- Go語言指針使用分析與講解