【发布时间】:2019-01-11 09:15:00
【问题描述】:
我有以下程序。
package main
import (
"fmt"
"log"
"github.com/boltdb/bolt"
)
const dbFile = "testbolt.db"
const testBucket = "test"
func main() {
db, err := bolt.Open(dbFile, 0600, nil)
if err != nil {
log.Fatal(err)
}
defer db.Close()
err = db.Update(func(tx *bolt.Tx) error {
_, err := tx.CreateBucketIfNotExists([]byte(testBucket))
if err != nil {
return err
}
return nil
})
if err != nil {
log.Fatal("1", err)
}
err = db.Update(func(tx *bolt.Tx) error {
b := tx.Bucket([]byte(testBucket))
err := b.Put([]byte("l"), []byte("writesomething"))
return err
})
if err != nil {
log.Fatal("2", err)
}
var lastSth []byte
var lastSthCopy []byte
err = db.View(func(tx *bolt.Tx) error {
b := tx.Bucket([]byte(testBucket))
lastSth = b.Get([]byte("l"))
fmt.Printf("lastSth %s@%p\n", lastSth, lastSth)
lastSthCopy = make([]byte, len(lastSth))
copy(lastSth, lastSthCopy) // this line fails.
fmt.Printf("lastSth:%s@%p, lastSthCopy:%p\n", lastSth, lastSth, lastSthCopy)
return nil
})
if err != nil {
log.Fatal("3", err)
}
}
虽然打印lastSth 字节片的地址和值没问题,但将值复制到另一个字节片会出现以下错误。
lastSth writesomething@0xc94055
unexpected fault address 0xc94055
fatal error: fault
[signal 0xc0000005 code=0x1 addr=0xc94055 pc=0x4549de]
请指教。
【问题讨论】:
-
BoltDb Github 页面中有一个issue。你看到了吗?无论如何,您的问题无法通过任意字节切片直接复制来重现:play.golang.org/p/cYCscNE8FDW
-
是的,我已经看到了,但我相信问题涉及事务外部的引用,而这里的问题发生在事务内部,我很确定上面的代码可以重现问题(至少我得到了每次都这样)
标签: go segmentation-fault boltdb