gpt4 book ai didi

c - C 中使用 void 指针的通用堆栈不适用于字符串

转载 作者:太空宇宙 更新时间:2023-11-03 23:51:09 25 4
gpt4 key购买 nike

我正在尝试使用 void 指针在 C 中实现通用堆栈。这没什么大不了的,只是为了好玩和学习。它按预期使用 int 和 float。但我面临的问题是 char *,即字符串。它不是复制字符串的地址,而是尝试将实际字符串复制最多 4 个字节(因为我的系统指针大小是 4 个字节)。

如果可能的话,如何告诉 C 复制字符串的地址而不是实际的字符串,而不会破坏 int 和 float 已经工作的功能?

目前我的实现如下,


typedef struct{
int top;
void *data;
int capacity;
size_t ele_size;
}stack_t;

int stack_init(stack_t *s, int capacity, size_t ele_size)
{
/* Initializes the stack with the given capacity
* @param s: Pointer to stack_t type variable
* @param capacity: capacity of the stack to be created
* Returns : Zero if succesful in allocating memory to the stack,
* -1 Otherwise
*/
s->top = -1;
s->capacity = capacity;
s->ele_size = ele_size;
s->data = calloc(s->capacity, s->ele_size);
if (s-> data != NULL || s->capacity == 0) {
return 0;
} else {
return -1;
}
}

int stack_push(stack_t *s, void *x)
{
/* Pushes an element on to the stack
* @param s: Pointer to stack_t type variable
* @param x: Value to Push on to the stack
* Returns : Zero if stack is not full when stack_push() is called,
* -1 Otherwise
*/
if (stack_len(s) capacity) {
s->top++;
memcpy(s->data + s->ele_size * s->top, x, s->ele_size);
return 0;
} else {
return -1;
}
}

int stack_pop(stack_t *s, void *value)
{
/* Value that is popped from the stack is placed in value parameter,
* @param s: Pointer to stack_t type variable
* @param x: Pointer to a variable to store the value popped from the
stack
* Returns: Zero if stack is not empty when stack_pop() is called,
* -1 Otherwise
*/
if (stack_len(s) > 0) {
memcpy(value, s->data + s->ele_size * s->top, s->ele_size);
s->top--;
return 0;
} else {
return -1;
}
}

堆栈的完整实现请引用here

上面栈的使用方法如下:实际上有很多不相关的东西,比如使用伪随机数生成器来将随机数插入堆栈。



#include"../src/stack.h"

START_TEST(int_push_pop)
{
stack_t s;
int n = random() % 60267;
int *a = calloc(n, sizeof (int));
ck_assert_int_eq(stack_init(&s, n, sizeof (int)), 0);
int i;
for (i = 0; i = 0; i--) {
int value;
int x = stack_pop(&s, &value);
ck_assert_int_eq(x, 0);
ck_assert_int_eq(value, a[i]);
x = stack_len(&s);
ck_assert_int_eq(x, i);
}
stack_clear(&s);
stack_destroy(&s);
}

END_TEST

START_TEST(float_push_pop)
{
/* similar to int_push_pop, so ignored here. */
}

END_TEST


START_TEST(string_push_pop)
{
stack_t s;

char *str = "stack overflow";
stack_push(&s, str);
char **popval = malloc(sizeof(char *));
stack_pop(&s, popval);
printf("%s\n", popval);

stack_destroy(&s);

}

END_TEST


Suite* stack_suite()
{
Suite *s = suite_create("Stack");

TCase *tc_int = tcase_create("int");
/* Stack int data type Test Case*/

TCase *tc_float = tcase_create("float");
/* Stack float data type Test Case*/

tcase_add_test(tc_int, int_push_pop);
tcase_add_test(tc_float, float_push_pop);

suite_add_tcase(s, tc_int);
suite_add_tcase(s, tc_float);

return s;
}


int main()
{
int number_failed;
Suite *s = stack_suite();
SRunner *sr = srunner_create(s);
srunner_run_all(sr, CK_NORMAL);
number_failed = srunner_ntests_failed(sr);
srunner_free(sr);

return (number_failed == 0) ? EXIT_SUCCESS : EXIT_FAILURE;
}

最佳答案

由于 stack_push()stack_pop() 函数采用 void* 指针,您需要将指针传递给字符需要推送的数组(字符串)而不是 char 数组本身。例如如果您将字符串声明为

char str[] = "hello world";

你必须调用这个函数作为

stack_push(s,&str);

关于c - C 中使用 void 指针的通用堆栈不适用于字符串,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/19615146/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com