返回

如何将 C 字符串数组减少为唯一值

发布时间:2022-05-19 06:37:18 412
# 研究

我正在研究一个动态分配数组的基本框架。在这种情况下,它是一个字符串数组。我正在尝试创建一个函数来从数组中删除所有非唯一字符串值并使用 Google Test 对其进行测试。当我测试标题为的函数时unique_string_vec,出现以下错误。然而,公平地说,代码似乎工作正常,编译器本身并没有抛出错误。相反,谷歌测试似乎引发了错误。我正在尝试确定这是否是 google 测试的问题,或者我是否合法地有需要修复的内存管理问题。任何想法或建议将不胜感激。

unit_tests: malloc.c:2617: sysmalloc: Assertion (old_top == initial_top (av) && old_size == 0)

我将在下面发布框架的相关部分,并希望对如何解决该问题有任何想法。

vector.h

#ifndef ARRAY_H
#define ARRAY_H

#include 
#include 
#include 
#include 

typedef enum
{
    FLOAT,
    DOUBLE,
    CHAR,
    INT,
    STRING
} dat_type;
// --------------------------------------------------------------------------------

typedef struct
{
    char **array;
    size_t len;
    int elem;
    dat_type dat;
} StringVector;
// --------------------------------------------------------------------------------

int string_vector_mem_alloc(StringVector *array, size_t num_indices);
// --------------------------------------------------------------------------------

StringVector init_string_vector();
// --------------------------------------------------------------------------------

int append_string_vector(StringVector *s, char *value);
// --------------------------------------------------------------------------------

void pop_string_vector(StringVector *array, int index);
// --------------------------------------------------------------------------------

void unique_string_vec(StringVector *array);
// --------------------------------------------------------------------------------

void free_string_array(StringVector *array);
// --------------------------------------------------------------------------------
#endif /* ARRAY_H */

array.c

int string_vector_mem_alloc(StringVector *array, size_t num_indices) {
    // Determine the total memory allocation and assign to pointer
    void *pointer;
    pointer = malloc(num_indices * array->elem);

    // If memory is full fail gracefully
    if (pointer == NULL) {
        printf("Unable to allocate memory, exiting.\n");
        free(pointer);
        return 0;
    }
    // Allocate resources and instantiate Array
    else {
        array->array = pointer;
        array->len = 0;
        return 1;
    }
}
// --------------------------------------------------------------------------------

StringVector init_string_vector() {
    StringVector array;
    array.dat = STRING;
    array.elem = sizeof(char);
    string_vector_mem_alloc(&array, array.elem);
    return array;
}
// --------------------------------------------------------------------------------

int append_string_vector(StringVector *array, char *value) {
    value = strdup(value);
    if (!value) {
        return -1;
    }
    array->len++;
    char **resized = realloc(array->array, sizeof(char *)*array->len + 1);
    if (!resized) {
        free(value);
        return -1;
    }
    resized[array->len-1] = value;
    array->array = resized;
    return 0;
}
// --------------------------------------------------------------------------------

void pop_string_vector(StringVector *array, int index) {
    if (index >= array->len) {
        printf("Index %d out of bounds for pop_string_vector\n", index);
    }
    unsigned char **dst = (unsigned char **)array->array + index * array->elem;
    memmove(array->array + index, array->array + index + 1,  \
            sizeof *array->array * array->len -1);
    array->len -= 1;
}
// --------------------------------------------------------------------------------

void unique_string_vec(StringVector *array) {
    int repeat_status = 0;
    for (int i = 0; ; i++) {
        if (i >= array->len) break;
        for (int j = i + 1; ; j++) {
            if (j >= array->len) break;
            if (strcmp(array->array[i], array->array[j]) == 0){
                repeat_status = 1;
                pop_string_vector(array, j);
            }
        }
        if (repeat_status == 1) {
            pop_string_vector(array, i);
            repeat_status = 0;
            i -= 1;
        }
    }
}
// --------------------------------------------------------------------------------

void free_string_array(StringVector *array) {
    if (array != NULL) {
        for (int i = 0; i < array->len; i++) {
            free(array->array[i]);
        }
    }
    free(array->array);
    // Reset all variables in the struct
    array->array = NULL;
    array->len = 0;
    array->elem = 0;
}

test_vector.cpp

#include <gtest/gtest.h>

extern "C" {
#include "vector.h"
}

TEST(string, unique_string_vec) {
    StringVector arr_test = init_string_vector();
    char one[] = "Hello";
    char two[] = "World";
    char three[] = "Hello";
    char four[] = "Goodbye";
    append_string_vector(&arr_test, one);
    append_string_vector(&arr_test, two);
    append_string_vector(&arr_test, three);
    append_string_vector(&arr_test, four);
    // - Even though the code works correctly, I get an error thrown
    //   by google test when I apply this function
    unique_string_vec(&arr_test);
    // These produce the correct value
    printf("%s\n", arr_test.array[0]);
    printf("%s\n", arr_test.array[1]);
    printf("%d\n", arr_test.len);

//  EXPECT_EQ(arr_test.len, 2);
//  int result1 = strcmp(two, arr_test.array[0]);
//  int result2 = strcmp(four, arr_test.array[1]);

//  EXPECT_EQ(result1, 0);
//  EXPECT_EQ(result2, 0);
}
特别声明:以上内容(图片及文字)均为互联网收集或者用户上传发布,本站仅提供信息存储服务!如有侵权或有涉及法律问题请联系我们。
举报
评论区(0)
按点赞数排序
用户头像