迭代数组转换为void *

时间:2018-06-18 13:02:07

标签: c casting void-pointers

我创建了一个数组:

unsigned short* array = malloc(sizeof(unsigned short)*N);

为其指定值:

for(i=0; i<N; i++){
    array[i] = rand()%USHRT_MAX;
}

将其转换为void *并将其传递给工作线程,该线程将在数组中找到最大值:

pthread_create(&threads[0], NULL, findMax, (void*)&array);

看起来像这样:

void* findMax(void* arg){
    int i = 0;
    unsigned short max = 0;
    unsigned short* table = (unsigned short*)arg;
    for(i=0;i<N;i++){
        if(table[i]> max){
            max = table[i];
        }
    }
    printf("Max: %d\n", max);
}

问题是数组中指定的数字格式错误。例如,使用N个随机生成的数字:3664 50980 37495 12215 33721,此循环将解释数字如下:

table[0] = 28680
table[1] = 2506
table[2] = 5
table[3] = 0
table[4] = 32736

在阵列的第2和第3位上使用5和0作为重复模式。

我明显超越了一些记忆界限,这里发生了什么,我该如何解决?

2 个答案:

答案 0 :(得分:11)

变化:

(void*)&array

到此:

(void*)array

因为void* findMax(void* arg)需要一个指针,并且你传递了指针的地址。

答案 1 :(得分:0)

指针变量是使用派生类型说明符声明的变量。 它仍然是一个变量,它仍然有一个地址。 该地址的值是该类型变量的地址。

“指针类型”通常是指void*,而短指针指向short*,依此类推。 void指针可以指向任何变量,但是当使用它时,你必须使用类型转换将它转换为泛型类型的指针, 因此,当您将其转换为其他内容时,您只会转换为void *。

因此,如果将&符号(引用)运算符添加到指针&ptr,则最终会引用指针变量的地址。如果要从函数中“重新指定”指针,它会很有用。

您的代码仍然可以成功,但您必须以不同方式声明参数:

foo(void** vp)) 要访问它指向的变量,您可以取消引用void **:

void* p = *vp;