⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 tcbmttest.c

📁 Tokyo Cabinet的Tokyo Cabinet 是一个DBM的实现。这里的数据库由一系列key-value对的记录构成。key和value都可以是任意长度的字节序列,既可以是二进制也可以是字符
💻 C
📖 第 1 页 / 共 4 页
字号:
/************************************************************************************************* * The test cases of the B+ tree database API *                                                      Copyright (C) 2006-2009 Mikio Hirabayashi * This file is part of Tokyo Cabinet. * Tokyo Cabinet is free software; you can redistribute it and/or modify it under the terms of * the GNU Lesser General Public License as published by the Free Software Foundation; either * version 2.1 of the License or any later version.  Tokyo Cabinet is distributed in the hope * that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU Lesser General Public * License for more details. * You should have received a copy of the GNU Lesser General Public License along with Tokyo * Cabinet; if not, write to the Free Software Foundation, Inc., 59 Temple Place, Suite 330, * Boston, MA 02111-1307 USA. *************************************************************************************************/#include <tcutil.h>#include <tcbdb.h>#include "myconf.h"#define RECBUFSIZ      48                // buffer for recordstypedef struct {                         // type of structure for write thread  TCBDB *bdb;  int rnum;  bool rnd;  int id;} TARGWRITE;typedef struct {                         // type of structure for read thread  TCBDB *bdb;  int rnum;  bool wb;  bool rnd;  int id;} TARGREAD;typedef struct {                         // type of structure for remove thread  TCBDB *bdb;  int rnum;  bool rnd;  int id;} TARGREMOVE;typedef struct {                         // type of structure for wicked thread  TCBDB *bdb;  int rnum;  bool nc;  int id;  TCMAP *map;} TARGWICKED;typedef struct {                         // type of structure for typical thread  TCBDB *bdb;  int rnum;  bool nc;  int rratio;  int id;} TARGTYPICAL;typedef struct {                         // type of structure for race thread  TCBDB *bdb;  int rnum;  int id;} TARGRACE;/* global variables */const char *g_progname;                  // program nameunsigned int g_randseed;                 // random seedint g_dbgfd;                             // debugging output/* function prototypes */int main(int argc, char **argv);static void usage(void);static void iprintf(const char *format, ...);static void iputchar(int c);static void eprint(TCBDB *bdb, const char *func);static void mprint(TCBDB *bdb);static void sysprint(void);static int myrand(int range);static int myrandnd(int range);static bool iterfunc(const void *kbuf, int ksiz, const void *vbuf, int vsiz, void *op);static int runwrite(int argc, char **argv);static int runread(int argc, char **argv);static int runremove(int argc, char **argv);static int runwicked(int argc, char **argv);static int runtypical(int argc, char **argv);static int runrace(int argc, char **argv);static int procwrite(const char *path, int tnum, int rnum, int lmemb, int nmemb,                     int bnum, int apow, int fpow, int opts, int omode, bool rnd);static int procread(const char *path, int tnum, int omode, bool wb, bool rnd);static int procremove(const char *path, int tnum, int omode, bool rnd);static int procwicked(const char *path, int tnum, int rnum, int opts, int omode, bool nc);static int proctypical(const char *path, int tnum, int rnum, int lmemb, int nmemb,                       int bnum, int apow, int fpow, int opts, int omode, bool nc, int rratio);static int procrace(const char *path, int tnum, int rnum, int lmemb, int nmemb,                    int bnum, int apow, int fpow, int opts, int omode);static void *threadwrite(void *targ);static void *threadread(void *targ);static void *threadremove(void *targ);static void *threadwicked(void *targ);static void *threadtypical(void *targ);static void *threadrace(void *targ);/* main routine */int main(int argc, char **argv){  g_progname = argv[0];  const char *ebuf = getenv("TCRNDSEED");  g_randseed = ebuf ? tcatoix(ebuf) : tctime() * 1000;  srand(g_randseed);  ebuf = getenv("TCDBGFD");  g_dbgfd = ebuf ? tcatoix(ebuf) : UINT16_MAX;  if(argc < 2) usage();  int rv = 0;  if(!strcmp(argv[1], "write")){    rv = runwrite(argc, argv);  } else if(!strcmp(argv[1], "read")){    rv = runread(argc, argv);  } else if(!strcmp(argv[1], "remove")){    rv = runremove(argc, argv);  } else if(!strcmp(argv[1], "wicked")){    rv = runwicked(argc, argv);  } else if(!strcmp(argv[1], "typical")){    rv = runtypical(argc, argv);  } else if(!strcmp(argv[1], "race")){    rv = runrace(argc, argv);  } else {    usage();  }  return rv;}/* print the usage and exit */static void usage(void){  fprintf(stderr, "%s: test cases of the B+ tree database API of Tokyo Cabinet\n", g_progname);  fprintf(stderr, "\n");  fprintf(stderr, "usage:\n");  fprintf(stderr, "  %s write [-tl] [-td|-tb|-tt|-tx] [-nl|-nb] [-rnd] path tnum rnum"          " [lmemb [nmemb [bnum [apow [fpow]]]]]\n", g_progname);  fprintf(stderr, "  %s read [-nl|-nb] [-wb] [-rnd] path tnum\n", g_progname);  fprintf(stderr, "  %s remove [-nl|-nb] [-rnd] path tnum\n", g_progname);  fprintf(stderr, "  %s wicked [-tl] [-td|-tb|-tt|-tx] [-nl|-nb] [-nc] path tnum rnum\n",          g_progname);  fprintf(stderr, "  %s typical [-tl] [-td|-tb|-tt|-tx] [-nl|-nb] [-nc] [-rr num] path tnum rnum"          " [lmemb [nmemb [bnum [apow [fpow]]]]]\n", g_progname);  fprintf(stderr, "  %s race [-tl] [-td|-tb|-tt|-tx] [-nl|-nb] path tnum rnum"          " [lmemb [nmemb [bnum [apow [fpow]]]]]\n", g_progname);  fprintf(stderr, "\n");  exit(1);}/* print formatted information string and flush the buffer */static void iprintf(const char *format, ...){  va_list ap;  va_start(ap, format);  vprintf(format, ap);  fflush(stdout);  va_end(ap);}/* print a character and flush the buffer */static void iputchar(int c){  putchar(c);  fflush(stdout);}/* print error message of hash database */static void eprint(TCBDB *bdb, const char *func){  const char *path = tcbdbpath(bdb);  int ecode = tcbdbecode(bdb);  fprintf(stderr, "%s: %s: %s: error: %d: %s\n",          g_progname, path ? path : "-", func, ecode, tcbdberrmsg(ecode));}/* print members of hash database */static void mprint(TCBDB *bdb){  if(bdb->hdb->cnt_writerec < 0) return;  iprintf("max leaf member: %d\n", tcbdblmemb(bdb));  iprintf("max node member: %d\n", tcbdbnmemb(bdb));  iprintf("leaf number: %d\n", tcbdblnum(bdb));  iprintf("node number: %d\n", tcbdbnnum(bdb));  iprintf("bucket number: %lld\n", (long long)tcbdbbnum(bdb));  iprintf("used bucket number: %lld\n", (long long)tcbdbbnumused(bdb));  iprintf("cnt_saveleaf: %lld\n", (long long)bdb->cnt_saveleaf);  iprintf("cnt_loadleaf: %lld\n", (long long)bdb->cnt_loadleaf);  iprintf("cnt_killleaf: %lld\n", (long long)bdb->cnt_killleaf);  iprintf("cnt_adjleafc: %lld\n", (long long)bdb->cnt_adjleafc);  iprintf("cnt_savenode: %lld\n", (long long)bdb->cnt_savenode);  iprintf("cnt_loadnode: %lld\n", (long long)bdb->cnt_loadnode);  iprintf("cnt_adjnodec: %lld\n", (long long)bdb->cnt_adjnodec);  iprintf("cnt_writerec: %lld\n", (long long)bdb->hdb->cnt_writerec);  iprintf("cnt_reuserec: %lld\n", (long long)bdb->hdb->cnt_reuserec);  iprintf("cnt_moverec: %lld\n", (long long)bdb->hdb->cnt_moverec);  iprintf("cnt_readrec: %lld\n", (long long)bdb->hdb->cnt_readrec);  iprintf("cnt_searchfbp: %lld\n", (long long)bdb->hdb->cnt_searchfbp);  iprintf("cnt_insertfbp: %lld\n", (long long)bdb->hdb->cnt_insertfbp);  iprintf("cnt_splicefbp: %lld\n", (long long)bdb->hdb->cnt_splicefbp);  iprintf("cnt_dividefbp: %lld\n", (long long)bdb->hdb->cnt_dividefbp);  iprintf("cnt_mergefbp: %lld\n", (long long)bdb->hdb->cnt_mergefbp);  iprintf("cnt_reducefbp: %lld\n", (long long)bdb->hdb->cnt_reducefbp);  iprintf("cnt_appenddrp: %lld\n", (long long)bdb->hdb->cnt_appenddrp);  iprintf("cnt_deferdrp: %lld\n", (long long)bdb->hdb->cnt_deferdrp);  iprintf("cnt_flushdrp: %lld\n", (long long)bdb->hdb->cnt_flushdrp);  iprintf("cnt_adjrecc: %lld\n", (long long)bdb->hdb->cnt_adjrecc);}/* print system information */static void sysprint(void){  TCMAP *info = tcsysinfo();  if(info){    tcmapiterinit(info);    const char *kbuf;    while((kbuf = tcmapiternext2(info)) != NULL){      iprintf("sys_%s: %s\n", kbuf, tcmapiterval2(kbuf));    }    tcmapdel(info);  }}/* get a random number */static int myrand(int range){  if(range < 2) return 0;  int high = (unsigned int)rand() >> 4;  int low = range * (rand() / (RAND_MAX + 1.0));  low &= (unsigned int)INT_MAX >> 4;  return (high + low) % range;}/* get a random number based on normal distribution */static int myrandnd(int range){  int num = (int)tcdrandnd(range >> 1, range / 10);  return (num < 0 || num >= range) ? 0 : num;}/* iterator function */static bool iterfunc(const void *kbuf, int ksiz, const void *vbuf, int vsiz, void *op){  unsigned int sum = 0;  while(--ksiz >= 0){    sum += ((char *)kbuf)[ksiz];  }  while(--vsiz >= 0){    sum += ((char *)vbuf)[vsiz];  }  return myrand(100 + (sum & 0xff)) > 0;}/* parse arguments of write command */static int runwrite(int argc, char **argv){  char *path = NULL;  char *tstr = NULL;  char *rstr = NULL;  char *lmstr = NULL;  char *nmstr = NULL;  char *bstr = NULL;  char *astr = NULL;  char *fstr = NULL;  int opts = 0;  int omode = 0;  bool rnd = false;  for(int i = 2; i < argc; i++){    if(!path && argv[i][0] == '-'){      if(!strcmp(argv[i], "-tl")){        opts |= BDBTLARGE;      } else if(!strcmp(argv[i], "-td")){        opts |= BDBTDEFLATE;      } else if(!strcmp(argv[i], "-tb")){        opts |= BDBTBZIP;      } else if(!strcmp(argv[i], "-tt")){        opts |= BDBTTCBS;      } else if(!strcmp(argv[i], "-tx")){        opts |= BDBTEXCODEC;      } else if(!strcmp(argv[i], "-nl")){        omode |= BDBONOLCK;      } else if(!strcmp(argv[i], "-nb")){        omode |= BDBOLCKNB;      } else if(!strcmp(argv[i], "-rnd")){        rnd = true;      } else {        usage();      }    } else if(!path){      path = argv[i];    } else if(!tstr){      tstr = argv[i];    } else if(!rstr){      rstr = argv[i];    } else if(!lmstr){      lmstr = argv[i];    } else if(!nmstr){      nmstr = argv[i];    } else if(!bstr){      bstr = argv[i];    } else if(!astr){      astr = argv[i];    } else if(!fstr){      fstr = argv[i];    } else {      usage();    }  }  if(!path || !tstr || !rstr) usage();  int tnum = tcatoix(tstr);  int rnum = tcatoix(rstr);  if(tnum < 1 || rnum < 1) usage();  int lmemb = lmstr ? tcatoix(lmstr) : -1;  int nmemb = nmstr ? tcatoix(nmstr) : -1;  int bnum = bstr ? tcatoix(bstr) : -1;  int apow = astr ? tcatoix(astr) : -1;  int fpow = fstr ? tcatoix(fstr) : -1;  int rv = procwrite(path, tnum, rnum, lmemb, nmemb, bnum, apow, fpow, opts, omode, rnd);  return rv;}/* parse arguments of read command */static int runread(int argc, char **argv){  char *path = NULL;  char *tstr = NULL;  int omode = 0;  bool rnd = false;  bool wb = false;  for(int i = 2; i < argc; i++){    if(!path && argv[i][0] == '-'){      if(!strcmp(argv[i], "-nl")){        omode |= BDBONOLCK;      } else if(!strcmp(argv[i], "-nb")){        omode |= BDBOLCKNB;      } else if(!strcmp(argv[i], "-wb")){        wb = true;      } else if(!strcmp(argv[i], "-rnd")){        rnd = true;      } else {        usage();      }    } else if(!path){      path = argv[i];    } else if(!tstr){      tstr = argv[i];    } else {      usage();    }  }  if(!path || !tstr) usage();  int tnum = tcatoix(tstr);  if(tnum < 1) usage();  int rv = procread(path, tnum, omode, wb, rnd);  return rv;}/* parse arguments of remove command */static int runremove(int argc, char **argv){  char *path = NULL;  char *tstr = NULL;  int omode = 0;  bool rnd = false;  for(int i = 2; i < argc; i++){    if(!path && argv[i][0] == '-'){      if(!strcmp(argv[i], "-nl")){        omode |= BDBONOLCK;      } else if(!strcmp(argv[i], "-nb")){        omode |= BDBOLCKNB;      } else if(!strcmp(argv[i], "-rnd")){        rnd = true;      } else {        usage();      }    } else if(!path){      path = argv[i];    } else if(!tstr){      tstr = argv[i];    } else {      usage();    }  }  if(!path || !tstr) usage();  int tnum = tcatoix(tstr);  if(tnum < 1) usage();  int rv = procremove(path, tnum, omode, rnd);  return rv;}/* parse arguments of wicked command */static int runwicked(int argc, char **argv){  char *path = NULL;  char *tstr = NULL;  char *rstr = NULL;  int opts = 0;  int omode = 0;  bool nc = false;  for(int i = 2; i < argc; i++){    if(!path && argv[i][0] == '-'){      if(!strcmp(argv[i], "-tl")){        opts |= BDBTLARGE;      } else if(!strcmp(argv[i], "-td")){        opts |= BDBTDEFLATE;      } else if(!strcmp(argv[i], "-tb")){        opts |= BDBTBZIP;      } else if(!strcmp(argv[i], "-tt")){        opts |= BDBTTCBS;      } else if(!strcmp(argv[i], "-tx")){        opts |= BDBTEXCODEC;      } else if(!strcmp(argv[i], "-nl")){        omode |= BDBONOLCK;      } else if(!strcmp(argv[i], "-nb")){        omode |= BDBOLCKNB;      } else if(!strcmp(argv[i], "-nc")){        nc = true;      } else {        usage();      }

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -