19
我想通過Mmap將數組映射到文件,數組可以是任何類型,如float64。在C中,我找到了這個one。讀完一些文章後,我寫了這個sample。我不知道它是否正確,並且不會將值寫入文件。如果我增加陣列的大小,例如從1000到10000,它會崩潰。如果有人知道如何以正確的方式做到這一點,請告訴我。通過Mmap將數組映射到文件中去
謝謝!
我想通過Mmap將數組映射到文件,數組可以是任何類型,如float64。在C中,我找到了這個one。讀完一些文章後,我寫了這個sample。我不知道它是否正確,並且不會將值寫入文件。如果我增加陣列的大小,例如從1000到10000,它會崩潰。如果有人知道如何以正確的方式做到這一點,請告訴我。通過Mmap將數組映射到文件中去
謝謝!
例如,修改你的示例程序,
package main
import (
"fmt"
"os"
"syscall"
"unsafe"
)
func main() {
const n = 1e3
t := int(unsafe.Sizeof(0)) * n
map_file, err := os.Create("/tmp/test.dat")
if err != nil {
fmt.Println(err)
os.Exit(1)
}
_, err = map_file.Seek(int64(t-1), 0)
if err != nil {
fmt.Println(err)
os.Exit(1)
}
_, err = map_file.Write([]byte(" "))
if err != nil {
fmt.Println(err)
os.Exit(1)
}
mmap, err := syscall.Mmap(int(map_file.Fd()), 0, int(t), syscall.PROT_READ|syscall.PROT_WRITE, syscall.MAP_SHARED)
if err != nil {
fmt.Println(err)
os.Exit(1)
}
map_array := (*[n]int)(unsafe.Pointer(&mmap[0]))
for i := 0; i < n; i++ {
map_array[i] = i * i
}
fmt.Println(*map_array)
err = syscall.Munmap(mmap)
if err != nil {
fmt.Println(err)
os.Exit(1)
}
err = map_file.Close()
if err != nil {
fmt.Println(err)
os.Exit(1)
}
}
謝謝,PeterSO,它的工作。你知道在Go中使用mmap是否安全? – tfmoraes 2012-02-09 11:05:57
「安全」是什麼意思?它重鑄了指針,因此需要「不安全」的包。如果你沒有正確處理指針,它可能會崩潰(並且GAE不允許首先使用不安全包的任何包)。但是,如果你正確處理它們,你可以編寫快速高效的程序。 Russ Cox(Go作者之一)的[codesearch](http://code.google.com/p/codesearch/)應用程序也使用mmap,因此您可能需要查看一下靈感。 – tux21b 2012-02-09 11:19:32
@ tux21b:我想知道是否可以使用例如Go GAE中的數學軟件包?請參閱[鏈接](http://golang.org/src/pkg/math/unsafe.go) – zzzz 2012-02-09 16:58:55