重新打开BerkeleyDB数据库会引发Segmentation故障

时间:2011-09-15 15:33:12

标签: c segmentation-fault berkeley-db

在以下计划中,我

  • 打开BDB环境
  • 打开数据库DB_BTREE / DB_CREATE
  • 关闭数据库
  • 以DB_UNKNOWN / DB_RDONLY ...
  • 重新打开数据库

但它引发了分段错误。

Program received signal SIGSEGV, Segmentation fault.
0x00000000004008e4 in main (argc=2, argv=0x7fffffffe888) at testbdb.c:38
38                  if ((ret = dbp1->open(dbp1,
为什么?

代码:

#include <stdio.h>
#include <stdlib.h>
#include <db.h>



int main(int argc,char** argv)
    {
    DB_ENV *dbenv=NULL;
        DB *dbp1=NULL;
        int ret;
        int i;
        if(argc!=2) return -1;

        if ((ret = db_env_create(&dbenv, 0)) != 0) {
            fprintf(stderr, "%s: %s\n", argv[0], db_strerror(ret));
            exit(-1);
        }


        if ((ret =
            dbenv->open(dbenv, argv[1], DB_CREATE | DB_INIT_MPOOL, 0)) != 0) {
            dbenv->err(dbenv, ret, "environment open: %s", argv[1]);
            exit(-1);
        }


        if ((ret = db_create(&dbp1, dbenv, 0)) != 0) {
            dbenv->err(dbenv, ret, "database create");
            exit(-1);
        }
        for( i=0;i<2;++i)
                {
                printf("open i=%d\n",i);
                if ((ret = dbp1->open(dbp1,
                        NULL,
                        "database1", "database1",
                        (i==0?DB_BTREE:DB_UNKNOWN),
                        (i==0?DB_CREATE:DB_RDONLY),
                        0)) != 0) {
                    dbenv->err(dbenv, ret, "DB->open: database1");
                     exit(-1);
                    }

                dbp1->close(dbp1, 0);
                printf("close i=%d\n",i);
                }


    (void)dbenv->close(dbenv, 0);
    return 0;
    }

1 个答案:

答案 0 :(得分:0)

根据documentation of the close() function“在调用DB-&gt; close()之后,可能无法再次访问DB句柄”这就是你的循环正在做的事情。这可能是一个开始寻找的好地方。