gpt4 book ai didi

c - 将变量 void* 赋给 void C 数组

转载 作者:行者123 更新时间:2023-11-30 18:51:54 25 4
gpt4 key购买 nike

所以我有一个数组,没有任何指定的类型:

void* buff = malloc(size*eltSize);

我有一个函数,它有一个 void* 参数,我想将它分配给数组,如下所示:

void function(void* p1){
buff[i] = p1;
}

我知道这不起作用,但是如果我想让它尽可能通用,最好的方法是什么?请记住,我不知道所使用的类型(它应该接受任何可能的类型;甚至struct)。谢谢

最佳答案

您每次都必须手动传递元素大小(以及数组索引),类似于 qsort 的工作原理。您必须将您的功能更改为:

void function(void * buff, void * p1, size_t elt_size, size_t index){
memcpy(((char *) buff) + index * elt_size, p1, elt_size);
}

并将其命名为:

int array[] = {3, 1, 4, 1, 5, 9};
int n = 8;
function(array, &n, sizeof(n), 5); // Equivalent to array[5] = n;

完整的工作示例:

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

void function(void * buf, void * data, size_t elt_size, size_t index)
{
memcpy(((char *) buf) + index * elt_size, data, elt_size);
}

int main(void)
{
int narray[] = {3, 1, 4, 1, 5, 9};
int n = 8;
function(narray, &n, sizeof(n), 5); // Equivalent to array[5] = n
for ( size_t i = 0; i < sizeof(narray) / sizeof(narray[0]); ++i ) {
printf("Value of element [%zu] is: %d\n", i, narray[i]);
}

char * sarray[] = {"The", "mome", "raths", "outgrabe"};
char * p = "barked";
function(sarray, &p, sizeof(p), 3); // Equivalent to sarray[3] = p
for ( size_t i = 0; i < sizeof(sarray) / sizeof(sarray[0]); ++i ) {
printf("Value of element [%zu] is: %s\n", i, sarray[i]);
}

return 0;
}

输出:

Paul@Pauls-iMac:~/Documents/src/sandbox$ ./generic2
Value of element [0] is: 3
Value of element [1] is: 1
Value of element [2] is: 4
Value of element [3] is: 1
Value of element [4] is: 5
Value of element [5] is: 8
Value of element [0] is: The
Value of element [1] is: mome
Value of element [2] is: raths
Value of element [3] is: barked
Paul@Pauls-iMac:~/Documents/src/sandbox$

显然,它对于使用 malloc() 动态分配的数组的工作效果与本示例使用的常规数组一样好。

如果您创建一个 struct 将数据和元素大小保存在一起,则可以消除每次传递元素大小的需要,例如:

struct generic_array {
void * data;
size_t elt_size;
}

当您将指向此struct的指针传递给您的函数时,它将能够访问元素大小本身,既不需要您提供它,又消除了整个类别由于您无意中传递了错误的尺寸而产生的错误。如果您添加第三个成员来存储您最初 malloc()ed 的元素数量,那么您也可以进行边界检查。

该方法的完整工作示例:

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

struct generic_array {
void * data;
size_t elt_size;
size_t size;
};

struct generic_array * generic_array_create(const size_t elt_size,
const size_t size)
{
struct generic_array * new_array = malloc(sizeof *new_array);
if ( !new_array ) {
perror("couldn't allocate memory for array");
exit(EXIT_FAILURE);
}

void * data = malloc(size * elt_size);
if ( !data ) {
perror("couldn't allocate memory for array data");
exit(EXIT_FAILURE);
}

new_array->data = data;
new_array->elt_size = elt_size;
new_array->size = size;

return new_array;
}

void generic_array_destroy(struct generic_array * array)
{
free(array->data);
free(array);
}

void generic_array_set(struct generic_array * array, void * elem,
const size_t index)
{
if ( index >= array->size ) {
fprintf(stderr, "Index %zu out of bounds of size %zu.\n",
index, array->size);
exit(EXIT_FAILURE);
}

memcpy(((char *)array->data) + index * array->elt_size,
elem, array->elt_size);
}


void generic_array_get(struct generic_array * array, void * elem,
const size_t index)
{
if ( index >= array->size ) {
fprintf(stderr, "Index %zu out of bounds of size %zu.\n",
index, array->size);
exit(EXIT_FAILURE);
}

memcpy(elem, ((char *)array->data) + index * array->elt_size,
array->elt_size);
}

int main(void)
{
int narray[] = {3, 1, 4, 1, 5, 9};
const size_t nsize = sizeof(narray) / sizeof(narray[0]);

struct generic_array * garray = generic_array_create(sizeof(int), nsize);

for ( size_t i = 0; i < nsize; ++i ) {
generic_array_set(garray, &narray[i], i);
}

for ( size_t i = 0; i < nsize; ++i ) {
int n;
generic_array_get(garray, &n, i);
printf("Value of element %zu: %d\n", i, n);
}

generic_array_destroy(garray);

return 0;
}

关于c - 将变量 void* 赋给 void C 数组,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/35675255/

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