error: invalid conversion from ‘void*’ to ‘void* (

2019-04-06 18:33发布

anisha@linux-y3pi:~> g++ conditionVarTEST.cpp -Wall

conditionVarTEST.cpp: In function ‘int main()’:
conditionVarTEST.cpp:33:53: error: invalid conversion from ‘void*’ to ‘void* (*)(void*)’
conditionVarTEST.cpp:33:53: error:   initializing argument 3 of ‘int pthread_create(pthread_t*, const pthread_attr_t*, void* (*)(void*), void*)’
conditionVarTEST.cpp:34:53: error: invalid conversion from ‘void*’ to ‘void* (*)(void*)’
conditionVarTEST.cpp:34:53: error:   initializing argument 3 of ‘int pthread_create(pthread_t*, const pthread_attr_t*, void* (*)(void*), void*)’

Line number 33 is this:

pthread_create (&A, NULL, (void *) &functionA, NULL);

Declaration of functionA is this:

void functionA (void*);


Its definition is:

void functionA (void* argA)
{
    while (1)
    {
        pthread_mutex_lock (&mutexA);

        if (count < 0)
        {
            pthread_cond_wait (&conditionVariableA, &mutexA);
        }
        else
        {
            // Do something.
            std :: cout << "\nTime to enjoy!";
        }
        pthread_mutex_unlock (&mutexA);
    }
}

4条回答
Deceive 欺骗
2楼-- · 2019-04-06 19:04

(void *) &functionA will cast your function pointer functionA which is of type void (*)(void*) to a simple void*. The later can't be converted to the first again, so the compiler reports an error. This is one of the reasons why you shouldn't use C-style casts.

Use pthread_create (&A, NULL, functionA, NULL); instead.

Also, the return type of a thread function should be void*, not void. So change void functionA(void*) to void* functionA(void*).

查看更多
Deceive 欺骗
3楼-- · 2019-04-06 19:12

Use

pthread_create (&A, NULL, functionA, NULL); 

instead of casting.

Also the function you use to pass to pthread_create should return a void* so to avoid any problems later, consider changing the function signature to accomodate this.

查看更多
Explosion°爆炸
4楼-- · 2019-04-06 19:16

And as you are using a C++ compiler, you should use a function with C binding, as pthread_create expects a C function:

extern "C" void* functionA (void*);

C++ and C may have the same calling conventions on your current platform, but there is no guaranty, that this will be the case on other platforms or will be so in the future.

查看更多
Emotional °昔
5楼-- · 2019-04-06 19:31

If you look at the manual page you will see that the function argument is

void *(*start_routine) (void *)

That is, a pointer to a function which takes one void * argument and returns void *.

To get rid of your errors, change your function to return void *, and pass it without type-casting it. The return from the thread function can be a simple return NULL if you don't care about the value.

查看更多
登录 后发表回答