-1

我正在 C 中实现一个代码,以便在字符数组( string )中复制一个字符串,然后对其进行 bsearch 。但出乎意料的是,对于应该为真的结果,bsearch 返回假。我猜这与我在插入过程中如何首先插入字符串有关。您可以将其视为对 btree 的叶节点的插入和搜索。

我在多文件框架中对此进行编码,因此无法发布所有代码。贴出相关部分

字符串数组的结构以便于可视化 -

array of strings ( array of array of chars ) 
                            --
                          0 -- array of characters ( size may be 5 )  
                          1 -- array of characters ( size may be 7 ) 
                          2 -- array of characters ( size may be 10 )

or

keys = [
         [ s t r i n g 1 ]
         [ s t r i n g T w o ]
         [ s t r i n g T H R E E ]
       ]

插入功能 -

void insert_in_leaf_node(struct leaf_node * node, u32 len, u8 * key){
    if (node->no_of_keys > 1 ) {
       if (!search_in_fat(node, len, key)) {
            node->keys[node->no_of_keys] = (char *) malloc(sizeof(char) * len);
            strncpy(node->keys[node->no_of_keys], (char *) key, len);                                                              // copy key to array
            node->keys[node->no_of_keys][len] = '\0';
            node->no_of_keys += 1;
            qsort(node->keys, (size_t) node->no_of_keys, sizeof(char *), cstring_cmp);                                          // sort alphabetically to enable bsearch later
        }
    } else {
        node->keys[node->no_of_keys] = (char *) malloc(sizeof(char) * len);
        strncpy(node->keys[node->no_of_keys], (char *) key, len);                                                              // copy key to array
        node->keys[node->no_of_keys][len] = '\0';
        node->no_of_keys += 1;
        qsort(node->keys, (size_t) node->no_of_keys, sizeof(char *), cstring_cmp);                                          // sort alphabetically to enable bsearch later
    }
}

搜索代码 -

bool search_in_fat(struct leaf_node * node, u32 len, u8 * key){
    if(!bsearch(key,node->keys,(size_t)node->no_of_keys, sizeof( char * ),(int(*)(const void*,const void*)) strcmp)) return false;
    return true;
}

插入函数中使用的 cstring_cmp 函数 -

int cstring_cmp(const void *a, const void *b)
{
    const char **ia = (const char **)a;
    const char **ib = (const char **)b;
    return strcmp(*ia, *ib);
    /* strcmp functions works exactly as expected from
    comparison function */
}

如果有人想知道键是什么,这里是一个键数组是如何更早地填充的,并且每次都使用单独的键调用一个 set / get 函数(set / get 函数调用上述函数)

从文件中跟踪加载以生成键数组的代码 - ( __samples 保存键)

bool
load_trace(const char * const filename)
{
  char * buf = NULL;
  size_t size = 0;
  FILE * fin = fopen(filename, "r");
  if (fin == NULL) return false;
  u64 i = 0;
  // count for lines
  while (getline(&buf, &size, fin) >= 1) {
    i++;
  }
  rewind(fin);
  __samples = malloc(sizeof(char *) * i);
  __sizes = malloc(sizeof(u32) * i);
  __nr_samples = i;
  ssize_t len = 0;
  i = 0;
  while ((len = getline(&buf, &size, fin)) >= 1) {
    if (buf[len-1] == '\n') { // remove trailing '\n'
      len--;
      buf[len] = '\0';
    }
    __samples[i] = strdup(buf);
    __sizes[i] = len;
    i++;
  }
  free(buf);
  fclose(fin);
  return true;
}

PS:这部分不是我写的,是我前辈搭建框架的时候写的。

可能是什么问题呢?我已经做了很多谷歌搜索,但还没有积极的结果。

谢谢你!

4

1 回答 1

1

您不能strcmp()作为bsearch(). 该函数需要指向要比较的元素的指针(在这种情况下是指向字符串指针的指针,尽管函数参数的实际类型必须是const void *),而strcmp()需要指向字符串的指针。有一个额外的间接层它无法处理。

您没有显示该功能,但cstring_cmp()您使用的功能qsort()可能可以使用。

比较函数的第一个参数bsearch()是作为键给出的指针,第二个参数是指向要比较的数组的当前元素的指针,在qsort()比较函数中,两个参数都是指向元素的指针。因此,如果您将 key 参数设置bsearch()为指向您正在寻找的东西的指针,那么两者都将使用相同的函数。换句话说,bsearch(&key, ...)是好的,bsearch(key, ...)不是的。您还可以使用bsearch()特定的比较函数来处理第二种情况。有关示例,请参见https://stackoverflow.com/a/15824981/9952196 。

于 2018-07-14T00:14:51.840 回答