我已經(jīng)閱讀了很多關(guān)于內(nèi)存中值對齊的重要性的內(nèi)容,因?yàn)樵L問未對齊的地址可能會減慢操作速度,或者顯然根本不起作用,具體取決于 CPU 架構(gòu)(參考https://syslog.ravelin.com/ go-and-memory-layout-6ef30c730d51)。但后來我注意到,在 Go 中實(shí)例化一個(gè)簡單的字符串時(shí),它經(jīng)常將字符串值存儲在未對齊的地址中。這可以通過運(yùn)行以下代碼看到:package mainimport ( "fmt" "unsafe" "reflect")func main() { testString:= "testString" fmt.Println(fmt.Sprintf("Data is at address %d", ((*reflect.StringHeader)(unsafe.Pointer(&testString))).Data))}在https://play.golang.org/p/d1eX0nP3AgV上運(yùn)行它時(shí),我不斷得到:Data is at address 11403051140305顯然不能被4or整除8。有人可以解釋一下為什么 Go 將該值存儲在一個(gè)未對齊的地址中嗎?使用對齊的不是更好嗎?這僅僅是為了不浪費(fèi)空間,同時(shí)依靠現(xiàn)代 CPU 可以處理它的事實(shí)?;蛘呤且?yàn)樘摂M內(nèi)存層抽象了物理內(nèi)存地址,實(shí)際上物理地址是正確對齊的?
為什么 Go 經(jīng)常將字符串的數(shù)據(jù)存儲在未對齊的地址
函數(shù)式編程
2022-05-18 17:03:20